欢迎访问 生活随笔!

生活随笔

当前位置: 首页 > 编程资源 > 编程问答 >内容正文

编程问答

微信小程序-04-详解介绍.json 配置文件

发布时间:2025/7/14 编程问答 42 豆豆
生活随笔 收集整理的这篇文章主要介绍了 微信小程序-04-详解介绍.json 配置文件 小编觉得挺不错的,现在分享给大家,帮大家做个参考.

致我自己:小程序开发不是简单一两天的事,一两天只能算是了解,有时候看多了会烦,感觉很熟悉了,其实只是对表面进行了解,对编程却知之甚少,小程序开发不是简单的改模板,一两天很多部分改模板可能都做不到,坚持!

微信小程序-04-详解介绍.json 配置文件

  • 宝典官方文档:
    https://developers.weixin.qq.com/miniprogram/dev/framework/MINA.html
  • 今天开始深度学习编程语法,岁大部分是拷贝官方文档,代码类都是我自己敲的,希望能自己敲一遍表格里的内容,熟悉一下都有哪种属性

文件目录结构

  • 之前大概提高到,没有细说

描述整体程序的 app 的根目录:

  • 小程序包含一个描述整体程序的 app 和多个描述各自页面的 page
    一个小程序主体部分由三个文件组成,必须放在项目的根目录,如下:
文件是否必须有该文件作用
app.js必须有小程序逻辑
app.json必须有小程序公共配置
app.wxss可以没有小程序公共样式表

描述各自页面的page的目录:

  • 小程序页面由四个文件组成,分别是:
文件类型是否必须有该文件作用
js必须有页面的逻辑
wxml必须有页面的结构
json可以没有页面的配置
wxss可以没有页面的样式表

【注意】:为了方便开发者减少配置项,描述页面的四个文件必须具有相同的路径与文件名

小程序配置和页面配置

全局配置 - 小程序的配置

  • app.json文件用来对微信小程序进行全局配置,决定页面文件的路径、窗口表现、设置网络超时时间、设置多 tab 等
  • 以下是一个包含了部分常用配置选项的 app.json :
{//决定页面文件的路径"pages": ["pages/index/index","pages/logs/index"],//窗口表现样式"window": {"navigationBarTitleText": "Demo"},//设置底部标签"tabBar": {"list": [{"pagePath": "pages/index/index","text": "首页"}, {"pagePath": "pages/logs/logs","text": "日志"}]},//设置网络超时时间"networkTimeout": {"request": 10000,"downloadFile": 10000},//开启调试,默认关闭"debug": true }

app.json 配置项列表

属性类型必填描述支持版本
pagesString Array页面的路径
windowObject全局的默认窗口表现样式
tabBarObject底部tab栏的表现样式
networkTimeoutObject网络超时时间
debugBoolean是否开启 debug 模式,默认关闭
functionalPagesBoolean是否启用插件功能页,默认关闭2.1.0
subPackagesObject Array分包结构配置1.7.3
workersStringWork 代码防止的目录1.9.9.
requiredBackgroundModesArray填需要在后台使用的能力,如【后台音乐播放】
pluginsObject使用到的插件1.9.6
preloadRuleObject分包预下载规则2.3.0
resizableBooleaniPad 小程序是否支持屏幕旋转,默认关闭2.3.0

app.json 配置项列表 - pages

  • 注意是 app.json 文件
  • 用于指定小程序由哪些页面组成,每一项都对应一个页面的 路径+文件名 信息。文件名不需要写文件后缀,框架会自动去寻找对于位置的 .json, .js, .wxml, .wxss 四个文件进行处理
  • 数组的第一项代表小程序的初始页面(首页)
  • 小程序中新增/删除页面,都需要对 pages 数组进行修改
  • 如开发目录为:
├── app.js ├── app.json ├── app.wxss ├── pages │ │── index │ │ ├── index.wxml │ │ ├── index.js │ │ ├── index.json │ │ └── index.wxss │ └── logs │ ├── logs.wxml │ └── logs.js └── utils
  • 则需要在 app.json 中写:
{"pages":[//第一项必须写首页"pages/index/index","pages/logs/logs"] }

app.json 配置项列表 - window

  • 用于设置小程序的状态栏、导航条、标题、窗口背景色
属性类型默认值
navigationBarBackgroundColorHexColor#000000导航栏背景颜色
windowObject全局的默认窗口表现样式
tabBarObject底部tab栏的表现样式
networkTimeoutObject网络超时时间
debugBoolean是否开启 debug 模式,默认关闭
functionalPagesBoolean是否启用插件功能页,默认关闭2.1.0
subPackagesObject Array分包结构配置1.7.3
workersStringWork 代码防止的目录1.9.9.
requiredBackgroundModesArray填需要在后台使用的能力,如【后台音乐播放】
pluginsObject使用到的插件1.9.6
preloadRuleObject分包预下载规则2.3.0
resizableBooleaniPad 小程序是否支持屏幕旋转,默认关闭2.3.0

注意:

  • 1.HexColor(十六进制颜色值),如"#ff00ff"
  • 2.navigationStyle 只在 app.json 中生效
  • 3.开启 custom 后,低版本客户端需要做好兼容。开发者工具基础库版本切到 1.7.0(不代表最低版本,只供调试用)可方便切到旧视觉
  • 4.客户端 6.7.2 版本开始,navigationStyle: custom 对 组件无效
  • 5.笔者注:新版本的 Boolean 对应的值:true/false,没有引号,也没有大写

app.json 示例截图:

  • app.json:
{"window":{"navigationBarBackgroundColor": "#ffffff","navigationBarTextStyle": "black","navigationBarTitleText": "微信接口功能演示","backgroundColor": "#eeeeee","backgroundTextStyle": "light"} }
  • 截图;

app.json 配置项列表 - tabBar

  • 注意是 app.json 文件
  • 如果小程序是一个多 tab 应用(客户端窗口的底部或顶部有 tab 栏可以切换页面),可以通过 tabBar 配置项指定 tab 栏的表现,以及 tab 切换时显示的对应页面
属性类型必填默认值描述
colorHexColortab 上的文字默认颜色
selectedColorHexColortab 上的文字选中时的颜色
backgroundColorHexColortab 的背景色
borderStyleStringblacktabbar上边框的颜色, 仅支持 black / white
listArraytab 的列表,详见 list 属性说明,最少2个、最多5个 tab
positionStringbottomtabBar的位置,仅支持 bottom / top

其中 list 接受一个数组,只能配置最少2个、最多5个 tab。tab 按数组的顺序排序,每个项都是一个对象,其属性值如下:

属性类型必填说明
pagePathString页面路径,必须在 pages 中先定义
textStringtab 上按钮文字
iconPathString图片路径,icon 大小限制为40kb,建议尺寸为 81px * 81px,不支持网络图片。
当 postion 为 top 时,不显示 icon。
selectedIconPathString选中时的图片路径,icon 大小限制为40kb,建议尺寸为 81px * 81px,不支持网络图片。
当 postion 为 top 时,不显示 icon。

app.json 配置项列表 - networkTimeout

  • 各类网络请求的超时时间,单位均为毫秒
属性类型必填默认值说明
requestNumber60000wx.request 的超时时间,单位毫秒。
connectSocketNumber60000wx.connectSocket 的超时时间,单位毫秒。
uploadFileNumber60000wx.uploadFile 的超时时间,单位毫秒。
downloadFileNumber60000wx.downloadFile 的超时时间,单位毫秒。

app.json 配置项列表 - debug

  • 可以在开发者工具中开启 debug 模式,在开发者工具的控制台面板,调试信息以 info 的形式给出,其信息有Page的注册,页面路由,数据更新,事件触发等。可以帮助开发者快速定位一些常见的问题

app.json 配置项列表 - functionalPages

  • 基础库 2.1.0 开始支持,低版本需做兼容处理
  • 启用插件功能页时,插件所有者小程序需要设置其 functionalPages 为 true

app.json 配置项列表 - subPackages

  • 微信客户端 6.6.0 ,基础库 1.7.3 及以上版本支持
  • 启用分包加载时,声明项目分包结构

app.json 配置项列表 - workers

  • 基础库 1.9.90 开始支持,低版本需做兼容处理
  • 使用 Worker 处理多线程任务时,设置 Worker 代码放置的目录

app.json 配置项列表 - requiredBackgroundModes

  • 微信客户端 6.7.2 及以上版本支持
  • 申明需要后台运行的能力,类型为数组。目前支持以下项目:
    • audio: 后台音乐播放
    • 如:
    {"pages": ["pages/index/index"],"requiredBackgroundModes": ["audio"] } 注:在此处申明了后台运行的接口,开发版和体验版上可以直接生效,正式版还需通过审核

app.json 配置项列表 - plugins

  • 基础库 1.9.6 开始支持,低版本需做兼容处理
  • 声明小程序需要使用的插件

app.json 配置项列表 - preloadRule

  • 基础库 2.3.0 开始支持,低版本需做兼容处理
  • 声明分包预下载的规则

app.json 配置项列表 - resizable

  • 基础库 2.3.0 开始支持,低版本需做兼容处理
  • 在 iPad 上运行的小程序可以设置支持屏幕旋转

页面配置

  • 每一个小程序页面也可以使用.json文件来对本页面的窗口表现进行配置
  • 页面的配置只能设置 app.json 中部分 window 配置项的内容,页面中配置项会覆盖 app.json 的 window 中相同的配置项

页面配置项列表

属性类型默认值描述
navigationBarBackgroundColorHexColor#000000导航栏背景颜色,如 #000000
navigationBarTextStyleStringwhite导航栏标题颜色,仅支持 black / white
navigationBarTitleTextString导航栏标题文字内容
backgroundColorHexColor#ffffff窗口的背景色
backgroundTextStyleStringdark下拉 loading 的样式,仅支持 dark / light
enablePullDownRefreshBooleanfalse是否全局开启下拉刷新。
详见 Page.onPullDownRefresh
onReachBottomDistanceNumber50页面上拉触底事件触发时距页面底部距离,单位为px。
详见 Page.onReachBottom
disableScrollBooleanfalse设置为 true 则页面整体不能上下滚动;只在页面配置中有效,无法在 app.json 中设置该项
{"navigationBarBackgroundColor": "#ffffff","navigationBarTextStyle": "black","navigationBarTitleText": "微信接口功能演示","backgroundColor": "#eeeeee","backgroundTextStyle": "light" }

页面的.json只能设置 window 相关的配置项,以决定本页面的窗口表现,所以无需写 window 这个键

更多文章链接:微信小程序

转载于:https://www.cnblogs.com/xpwi/p/9652610.html

总结

以上是生活随笔为你收集整理的微信小程序-04-详解介绍.json 配置文件的全部内容,希望文章能够帮你解决所遇到的问题。

如果觉得生活随笔网站内容还不错,欢迎将生活随笔推荐给好友。