搜尋
首頁微信小程式小程式開發Vue 和微信小程式的差異有哪些?比較分析

一、生命週期

先貼兩張圖:

vue生命週期

Vue 和微信小程式的差異有哪些?比較分析

小程式生命週期

Vue 和微信小程式的差異有哪些?比較分析

# 相較之下,小程式的鉤子函數要簡單得多。

vue的鉤子函數在跳轉新頁面時,鉤子函數都會觸發,但是小程式的鉤子函數,頁面不同的跳躍方式,觸發的鉤子並不一樣。 onLoad:頁面載入

一個頁面只會呼叫一次,可以在 onLoad 中取得開啟目前頁面所呼叫的 query 參數。

onShow:頁面顯示

每次開啟頁面都會呼叫一次。

onReady:頁面初次渲染完成

一個頁面只會呼叫一次,代表頁面已經準備妥當,可以和視圖層互動。

對介面的設定如 wx.setNavigationBarTitle請在 onReady之後設定。詳見生命週期。

onHide:頁面隱藏

navigateTo或底部tab切換時呼叫。

onUnload:頁面卸載

redirectTonavigateBack的時候呼叫。

資料請求

在頁面載入請求資料時,兩者鉤子的使用有些類似,vue一般會在createdmounted中請求數據,而在小程序,會在onLoadonShow中請求數據。

二、資料綁定

vue:vue動態綁定一個變數的值為元素的某個屬性的時候,會在變數前面加上冒號: ,例:

  1. <img  src="/static/imghwm/default1.png"  data-src="imgSrc"  class="lazy"  :/ alt="Vue 和微信小程式的差異有哪些?比較分析" >
    小程式:綁定某個變數的值為元素屬性時,會用兩個大括號括起來,如果不加括號,為被認為是字串。範例:
<image src="{{imgSrc}}"></image>

三、清單渲染

直接貼程式碼,兩者還是有些相似:

##vue:

<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; }
   ]
 }
})

小程式:

#

Page({
 data: {
   items: [
     { message: &#39;Foo&#39; },
     { message: &#39;Bar&#39; }
   ]
 }
})
 
<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的一點。

<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中的對應值。 下面是程式碼,可以感受一下:

<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中,綁定事件傳參挺簡單,只需要在觸發事件的方法中,把需要傳遞的資料作為形參傳入就可以了,例如:

<button @click="say(&#39;明天不上班&#39;)"></button>
new Vue({
 el: &#39;#app&#39;,
 methods:{
   say(arg){
   consloe.log(arg)
   }
 }
})

小程式

中,不能直接在綁定事件的方法中傳入參數,需要將參數作為屬性值,綁定到元素上的data-屬性上,然後在方法中,透過e.currentTarget.dataset.*的方式取得,從而完成參數的傳遞,很麻煩有沒有...

<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、在vue

components中註冊4、在範本中使用

//子组件 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

檔案中,將該檔案宣告為元件

 {
     "component": true
   }
3、在需要引進的父元件的json

文件中,在

usingComponents填入引入元件的元件名稱以及路徑 

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

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

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

具体代码:

 // 子组件
   <!--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接收,即可完成数据的传递,示例:

// 父组件 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. <tab-bar currentpage="index"></tab-bar>
    此处, “index”就是要向子组件传递的值。

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

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

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

//子组件中
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的值便可以获取到该子组件,然后便可以调用子组件中的任意方法,例如:

//子组件
<bar ref="bar"></bar>
//父组件
this.$ref.bar.子组件的方法

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

//子组件
<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

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版

Atom編輯器mac版下載

Atom編輯器mac版下載

最受歡迎的的開源編輯器

SecLists

SecLists

SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)