微信小程序之项目结构与配置
2017-01-20 16:33
302 查看
每个平台项目都有相应的项目结构与配置,一起来看一下微信小程序的项目结构。
文件结构
小程序包含一个描述整体程序的 app 和多个描述各自页面的 page。
一个小程序主体部分由三个文件组成,必须放在项目的根目录,如下:
![](http://img.blog.csdn.net/20170120151738358?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvaGVkb25nXzc3/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center)
一个小程序页面由四个文件组成,分别是:
![](http://img.blog.csdn.net/20170120151754921?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvaGVkb25nXzc3/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center)
项目结构如下:
![](http://img.blog.csdn.net/20170120151831250?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvaGVkb25nXzc3/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center)
项目配置
一个项目的大体结构就如上所示,下面来看看具体配置:
使用app.json文件来对微信小程序进行全局配置,决定页面文件的路径、窗口表现、设置网络超时时间、设置多 tab 等。
app.json 配置项列表
![](http://img.blog.csdn.net/20170120154330173?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvaGVkb25nXzc3/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center)
pages
接受一个数组,每一项都是字符串,来指定小程序由哪些页面组成。每一项代表对应页面的【路径+文件名】信息,数组的第一项代表小程序的初始页面。小程序中新增/减少页面,都需要对 pages 数组进行修改。
文件名不需要写文件后缀,因为框架会自动去寻找路径.json,.js,.wxml,.wxss的四个文件进行整合。
如开发目录为:
pages/
pages/index/index.wxml
pages/index/index.js
pages/index/index.wxss
pages/logs/logs.wxml
pages/logs/logs.js
app.js
app.json
app.wxss
则,我们需要在 app.json 中写
{
“pages”:[
“pages/index/index”
“pages/logs/logs”
]
}
window
用于设置小程序的状态栏、导航条、标题、窗口背景色。
![](http://img.blog.csdn.net/20170120162507310?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvaGVkb25nXzc3/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast)
注:HexColor(十六进制颜色值),如”#000fff”
官方一张图大家参考:
![](https://mp.weixin.qq.com/debug/wxadoc/dev/image/config.jpg?t=2017117)
tabBar
如果我们的小程序是一个多 tab 应用(客户端窗口的底部或顶部有 tab 栏可以切换页面),那么我们可以通过 tabBar 配置项指定 tab 栏的表现,以及 tab 切换时显示的对应页面。
Tip: 通过页面跳转(wx.navigateTo)或者页面重定向(wx.redirectTo)所到达的页面,即使它是定义在 tabBar 配置中的页面,也不会显示底部的 tab 栏。
tabBar 是一个数组,只能配置最少2个、最多5个 tab,tab 按数组的顺序排序。
属性说明:
![](http://img.blog.csdn.net/20170120162727562?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvaGVkb25nXzc3/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast)
其中 list 接受一个数组,数组中的每个项都是一个对象,其属性值如下:
![](http://img.blog.csdn.net/20170120162752923?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvaGVkb25nXzc3/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast)
![](https://mp.weixin.qq.com/debug/wxadoc/dev/image/tabbar.png?t=2017117)
networkTimeout
可以设置各种网络请求的超时时间。
属性说明:
![](http://img.blog.csdn.net/20170120162921781?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvaGVkb25nXzc3/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast)
debug
可以在开发者工具中开启 debug 模式,在开发者工具的控制台面板,调试信息以 info 的形式给出,其信息有Page的注册,页面路由,数据更新,事件触发 。 可以帮助开发者快速定位一些常见的问题。
page.json
每一个小程序页面也可以使用.json文件来对本页面的窗口表现进行配置。 页面的配置比app.json全局配置简单得多,只是设置 app.json 中的 window 配置项的内容,页面中配置项会覆盖 app.json 的 window 中相同的配置项。
页面的.json只能设置 window 相关的配置项,以决定本页面的窗口表现,所以无需写 window 这个键,如:
![](http://img.blog.csdn.net/20170120163053178?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvaGVkb25nXzc3/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast)
根据以上所说,看个简单gif图:
文件结构
小程序包含一个描述整体程序的 app 和多个描述各自页面的 page。
一个小程序主体部分由三个文件组成,必须放在项目的根目录,如下:
一个小程序页面由四个文件组成,分别是:
项目结构如下:
项目配置
一个项目的大体结构就如上所示,下面来看看具体配置:
使用app.json文件来对微信小程序进行全局配置,决定页面文件的路径、窗口表现、设置网络超时时间、设置多 tab 等。
{ "pages": [ "pages/index/index", "pages/logs/logs" ], "window": { "backgroundTextStyle": "light", "navigationBarBackgroundColor": "#000fff", "navigationBarTitleText": "微信小程序", "navigationBarTextStyle": "white", "backgroundColor": "#ffffff" }, "tabBar": { "list": [ { "pagePath": "pages/index/index", "text": "首页", "iconPath": "pages/assests/imgs/home_normal.png", "selectedIconPath": "pages/assests/imgs/home_pressed.png", "color": "#000000", "selectedColor": "#CED63A" }, { "pagePath": "pages/logs/logs", "text": "第二页", "iconPath": "pages/assests/imgs/second_normal.png", "selectedIconPath": "pages/assests/imgs/second_pressed.png", "color": "#000000", "selectedColor": "#CED63A" } ] }, "networkTimeout": { "request": 20000, "connectSocket": 20000, "uploadFile": 20000, "downloadFile": 20000 }, "debug": true }
app.json 配置项列表
pages
接受一个数组,每一项都是字符串,来指定小程序由哪些页面组成。每一项代表对应页面的【路径+文件名】信息,数组的第一项代表小程序的初始页面。小程序中新增/减少页面,都需要对 pages 数组进行修改。
文件名不需要写文件后缀,因为框架会自动去寻找路径.json,.js,.wxml,.wxss的四个文件进行整合。
如开发目录为:
pages/
pages/index/index.wxml
pages/index/index.js
pages/index/index.wxss
pages/logs/logs.wxml
pages/logs/logs.js
app.js
app.json
app.wxss
则,我们需要在 app.json 中写
{
“pages”:[
“pages/index/index”
“pages/logs/logs”
]
}
window
用于设置小程序的状态栏、导航条、标题、窗口背景色。
注:HexColor(十六进制颜色值),如”#000fff”
"window": { "backgroundTextStyle": "light", "navigationBarBackgroundColor": "#000fff", "navigationBarTitleText": "微信小程序", "navigationBarTextStyle": "white", "backgroundColor": "#dddeee" }
官方一张图大家参考:
![](https://mp.weixin.qq.com/debug/wxadoc/dev/image/config.jpg?t=2017117)
tabBar
如果我们的小程序是一个多 tab 应用(客户端窗口的底部或顶部有 tab 栏可以切换页面),那么我们可以通过 tabBar 配置项指定 tab 栏的表现,以及 tab 切换时显示的对应页面。
Tip: 通过页面跳转(wx.navigateTo)或者页面重定向(wx.redirectTo)所到达的页面,即使它是定义在 tabBar 配置中的页面,也不会显示底部的 tab 栏。
tabBar 是一个数组,只能配置最少2个、最多5个 tab,tab 按数组的顺序排序。
属性说明:
其中 list 接受一个数组,数组中的每个项都是一个对象,其属性值如下:
![](https://mp.weixin.qq.com/debug/wxadoc/dev/image/tabbar.png?t=2017117)
networkTimeout
可以设置各种网络请求的超时时间。
属性说明:
debug
可以在开发者工具中开启 debug 模式,在开发者工具的控制台面板,调试信息以 info 的形式给出,其信息有Page的注册,页面路由,数据更新,事件触发 。 可以帮助开发者快速定位一些常见的问题。
page.json
每一个小程序页面也可以使用.json文件来对本页面的窗口表现进行配置。 页面的配置比app.json全局配置简单得多,只是设置 app.json 中的 window 配置项的内容,页面中配置项会覆盖 app.json 的 window 中相同的配置项。
页面的.json只能设置 window 相关的配置项,以决定本页面的窗口表现,所以无需写 window 这个键,如:
{ "backgroundTextStyle": "light", "navigationBarBackgroundColor": "#000fff", "navigationBarTitleText": "查看启动日志", "navigationBarTextStyle": "white", "backgroundColor": "#ffffff" }
根据以上所说,看个简单gif图:
相关文章推荐
- 微信小程序基础-项目结构、app.json和视图层
- 微信小程序基础-项目结构、app.json和视图层
- 微信小程序自学第一课:工程目录结构与.json文件配置
- 微信小程序 项目实战(一)生命周期 配置服务器信息 splash启动页
- 微信小程序基础-项目结构、app.json和视图层
- 微信小程序开发手记之一:项目的代码结构
- 微信小程序----项目结构
- 微信小程序初体验-项目基本结构
- 微信小程序基础-项目结构、app.json和视图层
- 01:微信小程序结构和配置
- 微信小程序开发之入门篇(熟悉项目结构)
- 微信小程序教学第二章:小程序中级实战教程之预备篇 - 项目结构设计 |基于最新版1.0开发者工具
- 微信小程序入门基础(1)—项目结构及app.json
- 微信小程序基础-项目结构、app.json和视图层
- 微信小程序开发详解——项目结构分析和页面的框架结构MINA(MVVM)
- 微信小程序项目结构
- Atitit 项目源码管理 attilax著 1. 源码结构sdk目录结构 1 1.1. 源码分类,配置文件,主程序文件,sql文件 1 2. 源码管理,提交,更新,与同步 1 2.1. 源码同步
- 微信小程序-项目案例 (二)配置 tabBar
- 微信小程序项目 配置开发环境及全面了解小程序
- 第二弹:微信小程序开发思考总结—“文章阅读器和电影信息”项目实践---配置、首页面开发