• 技术文章 >微信小程序 >小程序开发

    微信小程序开发之MINA

    高洛峰高洛峰2017-02-10 13:16:49原创1569
    MINA的目标是通过尽可能简单,高效的方式让开发者可以在微信中开发具有原生APP体验的服务。运行MINA的项目必须要有微信web开发者工具和微信小程序的AppID,因为现在还处于内测阶段的原因,因此大部分数人还没有AppID,还好有大神已经破解了IDE,可以先体验下。

    MINA是微信开发小程序的框架:

    MINA的目标是通过尽可能简单,高效的方式让开发者可以在微信中开发具有原生APP体验的服务。

    运行MINA的项目必须要有微信web开发者工具和微信小程序的AppID,因为现在还处于内测阶段的原因,因此大部分数人还没有AppID,还好有大神已经破解了IDE,可以先体验下,详情请参考微信小程序开发资料收集

    MINA框架中有四种类型的文件:

    目录结构

    为了减少配置项,小程序中一个页面中的四个文件必须要有相同的路径和文件名,使用微信web开发者工具新建一个项目,可以看到他的目录结构是这样的:

    微信小程序开发之MINA

    其中app.js是程序的入口,app.json是项目的配置文件,app.wxss是全局配置的样式文件,logs和index文件夹是是单个页面的文件,utils用来存放常用的工具类文件夹。

    app.js

    app.js使用App()函数注册一个小程序,可以指定小程序的生命周期

    小程序的App()生命周期中三个事件可以监听:onLaunch,onShow,onHide。

    例如:

    App({   onLaunch: function () {      console.log('App Launch')   },   onShow: function () {     console.log('App Show')   },   onHide: function () {     console.log('App Hide')   },   globalData: {     hasLogin: false   } })

    其中app.js的globalData可以设置全局的变量,在一个页面中可以通过getApp()函数获取小程序的实例,使用App的getCurrentPage()可以获取到当前页面的实例。

    app.json

    app.json是小程序的全局配置包括:页面的路径,窗口表现,设置网络超时,开发模式等...

    "pages":[  "pages/index/index",  "pages/logs/logs"  ]

    配置的index和logs两个页面的路径,在这里使用相对路径配置页面路径。

    "window":{     "backgroundTextStyle":"light",     "navigationBarBackgroundColor": "#ffffff",     "navigationBarTitleText": "WeChat",     "navigationBarTextStyle":"black"   }

    使用的Color为十六进制的颜色值,比如"#ffffff"

    注意:

    其中navigationBarTextStyle,导航栏的颜色仅支持black/white。

    而backgroundTextStyle,下拉背景的样式仅支持dark/light。

    "tabBar":{     "color":"#dddddd",     "selectdColor":"#3cc51f",     "borderStyle":"black",     "backgroundColor":"#ffffff"   ,"list":[     {       "pagePath":"pages/index/index",       "iconPath":"image/wechat.png",       "selectedIconPath":"image/wechatHL.png",       "text":"主页"       },{     "pagePath":"pages/logs/logs",     "iconPath":"image/wechat.png",     "selectedIconPath":"image/wechatHL.png",     "text":"日志"   }] }

    这里设置了两个tab页:index和log,效果如下:

    微信小程序开发之MINA

    1. wx.request普通的http请求,配置为request

    2. wx.connect stock链接,配置为connectSocket

    3. wx.uploadFile上传文件,配置为uploadFile

    4. wx.downloadFile下载文件,配置为downloadFile

    配置单位为毫秒,例如:

    "networkTimeout": {     "request": 10000,     "connectSocket": 10000,     "uploadFile": 10000,     "downloadFile": 10000   }
    "debug": true

    app.wxss

    app.wxss中定义的的样式为全局样式,作用在每一个页面,在page中定义的.wxss文件为局部样式,只作用在局部,局部样式中的定义会覆盖app.wxss中定义的样式。

    样式的定义:

    .container {   height: 100%;   display: flex;   flex-direction: column;   align-items: center;   justify-content: space-between;   padding: 200rpx 0;   box-sizing: border-box; }

    其中200rpx中的rpx是reponslve pixel,可以根据屏幕的宽度进行自适应,在iPhone6上1rpx=0.5px=1物理像素。微信小程序建议设计以iPhone6为准

    样式的使用:

    <view class="container"> </view>

    page

    使用Page()函数来注册一个页面,为其指定页面的初始数据,生命周期函数,事件处理等。

    例如:

    Page({   data: {     logs: []   },   onLoad: function () {     this.setData({       logs: (wx.getStorageSync('logs') || []).map(function (log) {         return util.formatTime(new Date(log))       })     })   } })

    page另外使用的文件.wxml是页面文件,使用定义好一套标签语言,.wxss是局部样式文件,.json局部配置文件比如需要在一个单独的页面中设置他的navigationBarTitleText,可以在.json文件中设置:

    {     "navigationBarTitleText": "日志文件" }


    更多微信小程序开发之MINA相关文章请关注PHP中文网!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:微信 程序 MINA
    上一篇:微信小程序开发之http请求 下一篇:一个小时快速搭建微信小程序
    20期PHP线上班

    相关文章推荐

    精选22门好课,价值3725元,开通VIP免费学习!• 记录一次实践,看看小程序购物车动画怎么优化• 浅谈小程序确保每个页面都已登陆的方法• 浅析小程序中如何优雅地进行模块化处理?• 深入浅析小程序中的全局配置• 小程序中怎么对网络请求进行二次封装
    1/1

    PHP中文网