浅析Vue 和微信小程序的区别、比较


Posted in Javascript onAugust 03, 2018

写了vue项目和小程序,发现二者有许多相同之处,在此想总结一下二者的共同点和区别。

一、生命周期

先贴两张图:

vue生命周期

浅析Vue 和微信小程序的区别、比较

小程序生命周期

浅析Vue 和微信小程序的区别、比较

相比之下,小程序的钩子函数要简单得多。

vue的钩子函数在跳转新页面时,钩子函数都会触发,但是小程序的钩子函数,页面不同的跳转方式,触发的钩子并不一样。onLoad:页面加载

一个页面只会调用一次,可以在 onLoad 中获取打开当前页面所调用的 query 参数。

onShow:页面显示

每次打开页面都会调用一次。

onReady:页面初次渲染完成

一个页面只会调用一次,代表页面已经准备妥当,可以和视图层进行交互。

对界面的设置如 wx.setNavigationBarTitle请在 onReady之后设置。详见生命周期。

onHide:页面隐藏

当 navigateTo或底部tab切换时调用。

onUnload:页面卸载

当 redirectTo或 navigateBack的时候调用。

数据请求

在页面加载请求数据时,两者钩子的使用有些类似,vue一般会在 created或者 mounted中请求数据,而在小程序,会在 onLoad或者 onShow中请求数据。

二、数据绑定

vue:vue动态绑定一个变量的值为元素的某个属性的时候,会在变量前面加上冒号:,例:

<img :src="imgSrc"/>

小程序:绑定某个变量的值为元素属性时,会用两个大括号括起来,如果不加括号,为被认为是字符串。例:

<image src="{{imgSrc}}"></image>

三、列表渲染

直接贴代码,两者还是有些相似:

vue:

<ul id="example-1">
 <li v-for="item in items">
 {{ item.message }}
 </li>
</ul>

var example1 = new Vue({
 el: '#example-1',
 data: {
 items: [
  { message: 'Foo' },
  { message: 'Bar' }
 ]
 }
})

小程序:

Page({
 data: {
 items: [
  { message: 'Foo' },
  { message: 'Bar' }
 ]
 }
})

<text wx:for="{{items}}">{{item}}</text>

四、显示与隐藏元素

vue中,使用 v-if 和 v-show控制元素的显示和隐藏。

小程序中,使用 wx-if和 hidden控制元素的显示和隐藏。

五、事件处理

vue:使用 v-on:event绑定事件,或者使用 @event绑定事件,例如:

<button v-on:click="counter += 1">Add 1</button>
<button v-on:click.stop="counter+=1">Add1</button> //阻止事件冒泡

小程序中,全用 bindtap(bind+event),或者 catchtap(catch+event)绑定事件,例如:

<button bindtap="noWork">明天不上班</button>
<button catchtap="noWork">明天不上班</button> //阻止事件冒泡

六、数据双向绑定

1、设置值

在vue中,只需要再表单元素上加上 v-model,然后再绑定 data中对应的一个值,当表单元素内容发生变化时, data中对应的值也会相应改变,这是vue非常nice的一点。

<div id="app">
 <input v-model="reason" placeholder="填写理由" class='reason'/>
</div>

new Vue({
 el: '#app',
 data: {
 reason:''
 }
})

但是在小程序中,却没有这个功能。那怎么办呢?

当表单内容发生变化时,会触发表单元素上绑定的方法,然后在该方法中,通过 this.setData({key:value})来将表单上的值赋值给 data中的对应值。

下面是代码,可以感受一下:

<input bindinput="bindReason" placeholder="填写理由" class='reason' value='{{reason}}' name="reason" />

Page({
data:{
 reason:''
},
bindReason(e) {
 this.setData({
  reason: e.detail.value
 })
 }
})

当页面表单元素很多的时候,更改值就是一件体力活了。和小程序一比较,vue的 v-model简直爽的不要不要的。

2、取值

vue中,通过 this.reason取值。

小程序中,通过 this.data.reason取值。

七、绑定事件传参

在vue中,绑定事件传参挺简单,只需要在触发事件的方法中,把需要传递的数据作为形参传入就可以了,例如:

<button @click="say('明天不上班')"></button>

new Vue({
 el: '#app',
 methods:{
 say(arg){
 consloe.log(arg)
 }
 }
})

在 小程序中,不能直接在绑定事件的方法中传入参数,需要将参数作为属性值,绑定到元素上的 data-属性上,然后在方法中,通过 e.currentTarget.dataset.*的方式获取,从而完成参数的传递,很麻烦有没有...

<view class='tr' bindtap='toApprove' data-id="{{item.id}}"></view>
Page({
data:{
 reason:''
},
toApprove(e) {
 let id = e.currentTarget.dataset.id;
 }
})

八、父子组件通信

1、子组件的使用

在vue中,需要:

1、编写子组件

2、在需要使用的父组件中通过 import引入

3、在 vue的 components中注册

4、在模板中使用

//子组件 bar.vue
<template>
 <div class="search-box">
 <div @click="say" :title="title" class="icon-dismiss"></div>
 </div>
</template>
<script>
export default{
props:{
 title:{
  type:String,
  default:''
  }
 }
},
methods:{
 say(){
  console.log('明天不上班');
  this.$emit('helloWorld')
 }
}
</script>

// 父组件 foo.vue
<template>
 <div class="container">
 <bar :title="title" @helloWorld="helloWorld"></bar>
 </div>
</template>

<script>
import Bar from './bar.vue'
export default{
data:{
 title:"我是标题"
},
methods:{
 helloWorld(){
  console.log('我接收到子组件传递的事件了')
 }
},
components:{
 Bar
}
</script>

在小程序中,需要:

1、编写子组件

2、在子组件的 json文件中,将该文件声明为组件

{
 "component": true
}

3、在需要引入的父组件的 json文件中,在 usingComponents填写引入组件的组件名以及路径

"usingComponents": {
 "tab-bar": "../../components/tabBar/tabBar"
 }

4、在父组件中,直接引入即可

<tab-bar currentpage="index"></tab-bar>

具体代码:

// 子组件
<!--components/tabBar/tabBar.wxml-->
<view class='tabbar-wrapper'>
 <view class='left-bar {{currentpage==="index"?"active":""}}' bindtap='jumpToIndex'>
 <text class='iconfont icon-shouye'></text>
 <view>首页</view>
 </view>
 <view class='right-bar {{currentpage==="setting"?"active":""}}' bindtap='jumpToSetting'>
 <text class='iconfont icon-shezhi'></text>
 <view>设置</view>
 </view>
</view>

2、父子组件间通信

在vue中

父组件向子组件传递数据,只需要在子组件通过 v-bind传入一个值,在子组件中,通过 props接收,即可完成数据的传递,示例:

// 父组件 foo.vue
<template>
 <div class="container">
 <bar :title="title"></bar>
 </div>
</template>
<script>
import Bar from './bar.vue'
export default{
data:{
 title:"我是标题"
},
components:{
 Bar
}
</script>

// 子组件bar.vue
<template>
 <div class="search-box">
 <div :title="title" ></div>
 </div>
</template>
<script>
export default{
props:{
 title:{
  type:String,
  default:''
  }
 }
}
</script>

子组件和父组件通信可以通过 this.$emit将方法和数据传递给父组件。

在小程序中

父组件向子组件通信和vue类似,但是小程序没有通过 v-bind,而是直接将值赋值给一个变量,如下:

<tab-bar currentpage="index"></tab-bar>
此处, “index”就是要向子组件传递的值

在子组件 properties中,接收传递的值。

properties: {
 // 弹窗标题
 currentpage: {   // 属性名
  type: String,  // 类型(必填),目前接受的类型包括:String, Number, Boolean, Object, Array, null(表示任意类型)
  value: 'index'  // 属性初始值(可选),如果未指定则会根据类型选择一个
 }
 }

子组件向父组件通信和 vue也很类似,代码如下:

//子组件中
methods: { 
 // 传递给父组件
 cancelBut: function (e) {
  var that = this;
  var myEventDetail = { pickerShow: false, type: 'cancel' } // detail对象,提供给事件监听函数
  this.triggerEvent('myevent', myEventDetail) //myevent自定义名称事件,父组件中使用
 },
}

//父组件中
<bar bind:myevent="toggleToast"></bar>

// 获取子组件信息
toggleToast(e){
 console.log(e.detail)
}

如果父组件想要调用子组件的方法

vue会给子组件添加一个 ref属性,通过 this.$refs.ref的值便可以获取到该子组件,然后便可以调用子组件中的任意方法,例如:

//子组件
<bar ref="bar"></bar>

//父组件
this.$ref.bar.子组件的方法

小程序是给子组件添加 id或者 class,然后通过 this.selectComponent找到子组件,然后再调用子组件的方法,示例:

//子组件
<bar id="bar"></bar>

// 父组件
this.selectComponent('#id').syaHello()

小程序和vue在这点上太相似了,有木有。。

总结

以上所述是小编给大家介绍的Vue 和微信小程序的区别、比较,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
CSS和Javascript简单复习资料
Jun 29 Javascript
asp.net中System.Timers.Timer的使用方法
Mar 20 Javascript
jquery多选项卡效果实例代码(附效果图)
Mar 23 Javascript
javascript面向对象快速入门实例
Jan 13 Javascript
javascript拖拽应用实例(二)
Mar 25 Javascript
基于bootstrap插件实现autocomplete自动完成表单
May 07 Javascript
详解前端构建工具gulpjs的使用介绍及技巧
Jan 19 Javascript
Node.js读取文件内容示例
Mar 07 Javascript
layui form表单提交后实现自动刷新
Oct 25 Javascript
JS实现横向轮播图(中级版)
Jan 18 Javascript
CentOS 8.2服务器上安装最新版Node.js的方法
Dec 16 Javascript
低门槛开发iOS、Android、小程序应用的前端框架详解
Oct 16 Javascript
Vue 项目分环境打包的方法示例
Aug 03 #Javascript
如何在vue里添加好看的lottie动画
Aug 02 #Javascript
原生js实现form表单序列化的方法
Aug 02 #Javascript
详解基于Vue2.0实现的移动端弹窗(Alert, Confirm, Toast)组件
Aug 02 #Javascript
详解vue指令与$nextTick 操作DOM的不同之处
Aug 02 #Javascript
vue组件挂载到全局方法的示例代码
Aug 02 #Javascript
原生js封装的ajax方法示例
Aug 02 #Javascript
You might like
一段php加密解密的代码
2006/10/09 PHP
PHP几个数学计算的内部函数学习整理
2011/08/06 PHP
ueditor 1.2.6 使用方法说明
2013/07/24 PHP
PHP中__autoload和Smarty冲突的简单解决方法
2016/04/08 PHP
PHPMAILER实现PHP发邮件功能
2018/04/18 PHP
js几个不错的函数 $$()
2006/10/09 Javascript
Extjs学习笔记之二 初识Extjs之Form
2010/01/07 Javascript
通过判断JavaScript的版本实现执行不同的代码
2010/05/11 Javascript
JavaScript字符串插入、删除、替换函数使用示例
2013/07/25 Javascript
javascript eval(func())使用示例
2013/12/05 Javascript
Javascript将数字转化成为货币格式字符串
2016/06/22 Javascript
D3.js实现雷达图的方法详解
2016/09/22 Javascript
javascript 缓冲运动框架的实现
2017/09/29 Javascript
JavaScript轮播停留效果的实现思路
2018/05/24 Javascript
详解puppeteer使用代理
2018/12/27 Javascript
微信小程序仿今日头条导航栏滚动解析
2019/08/20 Javascript
js验证密码强度解析
2020/03/18 Javascript
[01:25:38]DOTA2-DPC中国联赛 正赛 VG vs LBZS BO3 第一场 1月19日
2021/03/11 DOTA
Python字符串格式化
2015/06/15 Python
python中如何使用正则表达式的非贪婪模式示例
2017/10/09 Python
对变量赋值的理解--Pyton中让两个值互换的实现方法
2017/11/29 Python
python 提取key 为中文的json 串方法
2018/12/31 Python
Python3解释器知识点总结
2019/02/19 Python
python虚拟环境完美部署教程
2019/08/06 Python
python的json包位置及用法总结
2020/06/21 Python
自定义html标记替换html5新增元素
2008/10/17 HTML / CSS
法国时尚品牌乐都特瑞士站:La Redoute瑞士
2016/09/05 全球购物
eBay加拿大站:eBay.ca
2019/06/20 全球购物
意大利领先的奢侈品在线时装零售商:MCLABELS
2020/10/13 全球购物
公司行政经理岗位职责
2013/12/24 职场文书
2014年度思想工作总结
2014/11/27 职场文书
2015年见习期工作总结
2014/12/12 职场文书
介绍信的写法
2015/01/31 职场文书
祝福语集锦:给百岁老人祝寿贺词
2019/11/19 职场文书
MySQL中IO问题的深入分析与优化
2022/04/02 MySQL
Docker 镜像介绍以及commit相关操作
2022/04/13 Servers