首页 微信小程序 小程序开发 Vue 和微信小程序的区别有哪些?对比分析

Vue 和微信小程序的区别有哪些?对比分析

Aug 09, 2018 am 11:21 AM

一、生命周期

先贴两张图:

vue生命周期

1.png

小程序生命周期

1.png

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

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

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

onShow:页面显示

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

onReady:页面初次渲染完成

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

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

onHide:页面隐藏

navigateTo或底部tab切换时调用。

onUnload:页面卸载

redirectTonavigateBack的时候调用。

数据请求

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

二、数据绑定

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

  1. 1

    <img :src="imgSrc"/>

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

1

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

登录后复制

三、列表渲染

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

vue:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

<ul id="example-1">

 <li v-for="item in items">

   {{ item.message }}

 </li>

</ul>

  

var example1 = new Vue({

 el: &#39;#example-1&#39;,

 data: {

   items: [

     { message: &#39;Foo&#39; },

     { message: &#39;Bar&#39; }

   ]

 }

})

登录后复制

小程序:

1

2

3

4

5

6

7

8

9

10

Page({

 data: {

   items: [

     { message: &#39;Foo&#39; },

     { message: &#39;Bar&#39; }

   ]

 }

})

  

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

登录后复制

四、显示与隐藏元素

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

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

五、事件处理

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

1

2

<button v-on:click="counter += 1">Add 1</button>

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

登录后复制

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

1

2

<button bindtap="noWork">明天不上班</button>

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

登录后复制

六、数据双向绑定

1、设置值

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

1

2

3

4

5

6

7

8

9

10

<p id="app">

   <input v-model="reason" placeholder="填写理由" class=&#39;reason&#39;/>

</p>

  

new Vue({

 el: &#39;#app&#39;,

 data: {

  reason:&#39;&#39;

 }

})

登录后复制

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

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

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

1

2

3

4

5

6

7

8

9

10

11

12

<input bindinput="bindReason" placeholder="填写理由" class=&#39;reason&#39; value=&#39;{{reason}}&#39; name="reason" />

  

Page({

data:{

   reason:&#39;&#39;

},

bindReason(e) {

   this.setData({

     reason: e.detail.value

   })

 }

})

登录后复制

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

2、取值

vue中,通过 this.reason取值。

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

七、绑定事件传参

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

1

2

3

4

5

6

7

8

9

<button @click="say(&#39;明天不上班&#39;)"></button>

new Vue({

 el: &#39;#app&#39;,

 methods:{

   say(arg){

   consloe.log(arg)

   }

 }

})

登录后复制

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

1

2

3

4

5

6

7

8

9

<view class=&#39;tr&#39; bindtap=&#39;toApprove&#39; data-id="{{item.id}}"></view>

Page({

data:{

   reason:&#39;&#39;

},

toApprove(e) {

   let id = e.currentTarget.dataset.id;

 }

})

登录后复制

八、父子组件通信

1、子组件的使用

在vue中,需要:

1、编写子组件

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

3、在 vuecomponents中注册

4、在模板中使用

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

//子组件 bar.vue

<template>

 <p class="search-box">

   <p @click="say" :title="title" class="icon-dismiss"></p>

 </p>

</template>

<script>

export default{

props:{

   title:{

      type:String,

      default:&#39;&#39;

     }

   }

},

methods:{

   say(){

      console.log(&#39;明天不上班&#39;);

      this.$emit(&#39;helloWorld&#39;)

   }

}

</script>

  

// 父组件 foo.vue

<template>

 <p class="container">

   <bar :title="title" @helloWorld="helloWorld"></bar>

 </p>

</template>

  

<script>

import Bar from &#39;./bar.vue&#39;

export default{

data:{

   title:"我是标题"

},

methods:{

   helloWorld(){

       console.log(&#39;我接收到子组件传递的事件了&#39;)

   }

},

components:{

   Bar

}

</script>

登录后复制

在小程序中,需要: 1、编写子组件 2、在子组件的 json文件中,将该文件声明为组件

1

2

3

{

    "component": true

  }

登录后复制

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

1

2

3

"usingComponents": {

       "tab-bar": "../../components/tabBar/tabBar"

     }

登录后复制

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

1

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

登录后复制
登录后复制

具体代码:

1

2

3

4

5

6

7

8

9

10

11

12

// 子组件

  <!--components/tabBar/tabBar.wxml-->

  <view class=&#39;tabbar-wrapper&#39;>

    <view class=&#39;left-bar {{currentpage==="index"?"active":""}}&#39; bindtap=&#39;jumpToIndex&#39;>

      <text class=&#39;iconfont icon-shouye&#39;></text>

      <view>首页</view>

    </view>

    <view class=&#39;right-bar {{currentpage==="setting"?"active":""}}&#39; bindtap=&#39;jumpToSetting&#39;>

      <text class=&#39;iconfont icon-shezhi&#39;></text>

      <view>设置</view>

    </view>

  </view>

登录后复制

2、父子组件间通信

在vue中

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

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

// 父组件 foo.vue

<template>

 <p class="container">

   <bar :title="title"></bar>

 </p>

</template>

<script>

import Bar from &#39;./bar.vue&#39;

export default{

data:{

   title:"我是标题"

},components:{

  Bar

}

</script>

  

// 子组件bar.vue

<template>

 <p class="search-box">

   <p :title="title" ></p>

 </p>

</template>

<script>

export default{

props:{

   title:{

      type:String,

      default:&#39;&#39;

     }

   }

}

</script>

登录后复制

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

在小程序中

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

  1. 1

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

    登录后复制
    登录后复制
    此处, “index”就是要向子组件传递的值。

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

1

2

3

4

5

6

7

properties: {

   // 弹窗标题

   currentpage: {            // 属性名

     type: String,     // 类型(必填),目前接受的类型包括:String, Number, Boolean, Object, Array, null(表示任意类型)

     value: &#39;index&#39;     // 属性初始值(可选),如果未指定则会根据类型选择一个

   }

 }

登录后复制

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

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

//子组件中

methods: {  

   // 传递给父组件

   cancelBut: function (e) {

     var that = this;

     var myEventDetail = { pickerShow: false, type: &#39;cancel&#39; } // detail对象,提供给事件监听函数

     this.triggerEvent(&#39;myevent&#39;, myEventDetail) //myevent自定义名称事件,父组件中使用

   },

}

  

//父组件中

<bar bind:myevent="toggleToast"></bar>

  

// 获取子组件信息

toggleToast(e){

   console.log(e.detail)

}

登录后复制

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

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

1

2

3

4

//子组件

<bar ref="bar"></bar>

//父组件

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

登录后复制

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

1

2

3

4

//子组件

<bar id="bar"></bar>

// 父组件

this.selectComponent(&#39;#id&#39;).syaHello()

登录后复制

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

相关推荐:

微信小程序里wx:for和wx:for-item有什么区别

微信小程序和App手机软件对比评测

以上是Vue 和微信小程序的区别有哪些?对比分析的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

<🎜>:泡泡胶模拟器无穷大 - 如何获取和使用皇家钥匙
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
Mandragora:巫婆树的耳语 - 如何解锁抓钩
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
北端:融合系统,解释
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

热门话题

Java教程
1668
14
CakePHP 教程
1428
52
Laravel 教程
1329
25
PHP教程
1273
29
C# 教程
1256
24