mpvue-编写微信小程序总结
一、写在前面:
.....最近在写一个微信小程序项目,在看完官方微信小程序开发文档后,有一种直接想“放弃”的念头;
.....使用微信小程序原生框架可以快速,方便,简洁的搭建项目,同时微信提供了新的一套‘语义化’标记语言wxml,以及独立出来的wxss样式表,并且js的交互逻辑支持ES6的语法,包括使用Promise等;除去框架本身之外,小程序还提供了一些常用的组件,包括Picker,slider,canvas,form表单等,能极大的提高开发者的效率,丰富的API完全能满足工作需求,如果你在没有接触类似 VUE 等MVVM主流前端框架之前,微信小程序原生框架无疑是最佳选择;
......但是,使用过vue后,你会发现小程序原生框架的数据绑定方式非常“臃肿”,代码编写不优雅简洁,语义化标签以及丰富的属性设置会大大增加学习成本,另一方面微信小程序开发者工具的IDE表现也总是差强人意,反应迟钝,wxml,wxss,js之间来回切换不流畅,导致开发效率低下......
......由于以上种种,我开始寻找新的框架编写小程序项目,首先找到的框架是圈内较热门的wepy,其次就是最近才发布的mpvue;
简介
......wepy 是腾讯开源的一套语法接近vue.js,快速开发小程序的框架,开源的较早,网上有很多资源,也有一些大厂使用。可想而知,原生小程序框架在设计上还是有一定的缺陷
......mpvue也就是今天要介绍的主角,是美团开源的一套快速开发小程序的前端框架,__按官网说可以实现小程序与H5界面使用一套代码,mpvue 继承自 Vue.js。并且,其技术规范和语法特点与 Vue.js 保持一致。对毫无小程序开发经验的同学来说无疑是大大的福利。mpvue官网
二、优势比较
值得注意的是,mpvue提供vuex进行数据状态管理,能满足复杂应用状态管理需求,这是其他框架都不具备的!
三、新建项目
- 通过 Vue.js 命令行工具 vue-cli,你只需在终端窗口输入几条简单命令,即可快速创建和启动一个带热重载、保存时静态检查、内置代码构建功能的小程序项目
- 创建完之后,在命令行执行:
npm run dev
编译成功后,用微信开发者工具打开webpack打包后的dist文件,即可进行开发了; - 项目文件结构:
小提示:
安装mpvue项目利用vue-cli脚手架工具,选择了对应的mpvue的模板,在安装过程中,cli脚手架工具会提醒您是否需要安装Vuex,,我建议您根据项目需求确认是否添加该配置,因为这里安装Vuex,工具根据vue模板会帮你自动搭建依赖关系并且转义后兼容小程序,如果您想在项目开发中添加Vux就要注意了,在安装过程中极有可能报错,由于mpvue开源时间较短,参考资料也很有限,为了避免不必要的麻烦,建议在搭建项目时就安装Vuex。
四、生命周期比较
vue生命周期
- beforeCreate————————在实例初始化之后,数据观测事件配置之前被调用
- created ————————在实例创建完成后被立即调用
- beforeMount ————————在挂载开始之前被调用
- mounted ————————el 被新创建的 vm.$el 替换挂载到实例上去之后调用该钩子
- beforeUpdate
- updated
- activated ————————keep-alive 组件激活时调用。
- deactivated
- beforeDestroy
- destroyed
注意:vue的create,mounted等生命周期钩子函数只执行一次,当组件创建并被挂载到DOM上以后,就不会执行了;
小程序生命周期
app 部分:
- onLaunch,初始化
- onShow,当小程序启动,或从后台进入前台显示
- onHide,当小程序从前台进入后台
page 部分:
- onLoad,监听页面加载
- onShow,监听页面显示
- onReady,监听页面初次渲染完成
- onHide,监听页面隐藏
- onUnload,监听页面卸载
- onPullDownRefresh,监听用户下拉动作
- onReachBottom,页面上拉触底事件的处理函数
- onShareAppMessage,用户点击右上角分享
- onPageScroll,页面滚动
- onTabItemTap, 当前是 tab 页时,点击 tab 时触发 (mpvue 0.0.16 支持)
五、使用总结
(1)生命周期钩子函数
mpvue团队建议开发者在mpvue中尽可能的不使用小程序的生命周期,实际工作中使用小程序的生命周期钩子函数也无大碍,有的程序员为了减少页面初始化时尽快的请求到服务器端的数据,故意将ajax请求写在onShow钩子函数里,而不是vue 的 mounted函数里;
我们来看看这样一个需求,下图所示的页面
(2)路由
在mpvue中没有继续延用vue路由的写法,而是继承小程序的一套解决方案,在工作中我们经常通过路由来传递参数,比如下面代码所示:
//在index页面,我们想跳转到apply页面,并传递id参数
let id = 10
const url = '/pages/apply/main?id=' + id
wx.navigateTo({ url})
小程序方法获取id
// 在apply.vue页面中
onLoad (options) {
let id = options.id
}
//注意:必须是在onLoad钩子函数往后的生命周期中获取
onShow (options) {
let id = options.id
}
mpvue-编写微信小程序总结的更多相关文章
- mpvue体验微信小程序开发
微信小程序 https://developers.weixin.qq.com/miniprogram/introduction/index.html?t=18082114 微信小程序是一种全新的连接用 ...
- mpvue开发微信小程序,分享按钮报错:`Cannot read property 'apply' of null`
用mpvue开发微信小程序,分享按钮报错:Cannot read property 'apply' of null onShareAppMessage 是于微信小程序Pages的生命周期钩子,顾这个方 ...
- 使用mpvue开发微信小程序
更多内容请查看 我的新博客 地址 : 前言 16年小程序刚出来的时候,就准备花点时间去学学.无奈现实中手上项目太多,一个接着一个,而且也没有开发小程序的需求,所以就一拖再拖. 直到上周,终于有一个小程 ...
- 用mpvue构建微信小程序
背景 由于机器人协会进行鼓励大家多读书的活动,所以为了可以更好的.更有效果,所以我跟会长提了一个建议,做一个微信小程序,那么为什么是微信小程序呢? 1.现在微信小程序比较好,用户也比较多:利用微信小程 ...
- 高效编写微信小程序
原文:https://isux.tencent.com/high-performance-wechat-app-development.html 前言 微信小程序是一个工程,就和盖房子一样,打好了地基 ...
- 利用mpvue开发微信小程序
最近公司部门负责人提出需求需要开发一款微信小程序,由于本人之前是做前端开发的,对于小程序开发一窍不通,但是很多时候我们都是把不会做变成我会学.于是便在网上寻找小程序开发教程,相比于相生的小程序开发,本 ...
- mpvue开发微信小程序
前段时间,美团开源了mpvue这个项目,使得我们又多了一种用来开发小程序的框架选项.由于mpvue框架是完全基于Vue框架的(重写了其runtime和compiler),因此在用法上面是高度和Vue一 ...
- 【微信小程序】使用vscode编写微信小程序项目
1. 在微信开发者工具(以下简称:开发者)中新建一个模板微信小程序 2. 在开发者中将模拟器分隔开 3. 设置在保存时编译 4. 在vscode中打开项目目录 5. 下载代码提示插件 这样就可以在vs ...
- mpvue实现微信小程序(欢迎踩坑)
最近刚使用mpvue完成了微信小程序的开发,写点东西,做个记录. 首先依旧是两个传送门: 微信小程序文档:[https://developers.weixin.qq.com/miniprogram/d ...
- mpvue开发微信小程序之时间+日期选择器
最近在做微信小程序,技术栈为mpvue+iview weapp组件库. 因项目需求,要用到日期+时间选择器,iview组件库目前还未提供时间日期选择器的组件,小程序官方组件日期时间也是分开的,在简书上 ...
随机推荐
- Process Order API - How To Scripts
In this Document Purpose Questions and Answers References APPLIES TO: Oracle Order Management ...
- 推荐大家在GitHub 上值得关注学习的 iOS 开源项目
GitHub上有很多不错的iOS开源项目,和大家特别推荐以下几个项目: 1. ReactiveCocoa GitHub链接:ReactiveCocoa/ReactiveCocoa GitHub自家的函 ...
- AngularJS进阶(四)ANGULAR.JS实现下拉菜单单选
ANGULAR.JS: NG-SELECT AND NG-OPTIONS PS:其实看英文文档比看中文文档更容易理解,前提是你的英语基础还可以.英文文档对于知识点讲述简明扼要,通俗易懂,而有些中文文档 ...
- 【Visual C++】游戏编程学习笔记之二:定时器的使用
本系列文章由@二货梦想家张程所写,转载请注明出处. 本文章链接:http://blog.csdn.net/terence1212/article/details/44195831 作者:ZeeCode ...
- utl_file包的使用
首先看一下oracle 脚本 /* # $Header: HTMomse12.sql 12.0.4 20121015 Support $ #+============================= ...
- Systemc在VC++2010安装方法及如何在VC++2010运行Noxim模拟器
Systemc在VC++2010的安装方法可以参考文档"Systemc with Microsoft Visual Studio 2008.pdf".本文档可以在"htt ...
- “《编程珠玑》(第2版)第2章”:A题(二分搜索)
A题是这样子的: 给定一个最多包含40亿个随机排列的32位整数的顺序文件,找出一个不在文件中的32位整数(在文件中至少缺失一个这样的数据——为什么?).在具有足够内存的情况下,如何解决该问题?如果有几 ...
- 能量最小化初探,graphcuts能量最小化调用
1.相对于能量函数来说,能量最小化的办法都有哪些? 梯度下降 模拟退火 图割 2.这个 跟最优化问题的求解,有什么联系跟区别呢? 基本上差不多,其实就是求出来了函数的一个最小值,我们看问题的时候不妨把 ...
- 关于最新的APP上架流程
苹果官方在2015年05-06月开发者中心进行了改版,网上的APP Store上架大部分都不一样了,自己研究总结一下,一个最新的上架教程以备后用 1.1.前期工作 首先你需要有一个苹果的开发者帐号,一 ...
- LeetCode之旅(17)-Ugly Number
题目: Write a program to check whether a given number is an ugly number. Ugly numbers are positive num ...