首頁  >  文章  >  微信小程式  >  微信小程式內怎樣動態綁定類別名

微信小程式內怎樣動態綁定類別名

php中世界最好的语言
php中世界最好的语言原創
2018-06-07 15:05:328722瀏覽

這次帶給大家微信小程式內怎樣動態綁定類別名,微信小程式內怎樣動態綁定類別名稱的注意事項有哪些,下面就是實戰案例,一起來看一下。

小程式 開發中遇到這樣一個問題...

排行榜開發的時候,前三名的樣式不同,其餘的樣式一樣。但是都是透過同一元素來遍歷的,當時卡了一下。後來發現有module模組化這個概念,於是查了下api,一下子就做出來了。

 

就是不同名次上邊的樣式依照實際狀況呈現效果。

模組化

我們可以將一些公共的程式碼抽離成為一個單獨的 js 文件,作為一個模組。模組只有透過 module.exports 或 exports 才能對外暴露介面。

通俗的將就是自身獨立,作用域只作用於該模組,與js互不影響。

主程式碼

module部分

<wxs module="rank">
 var indexof = function(index){
 switch(index){
 case 0:
 return 'first-price';
 break;
 case 1: 
 return 'second-price';
 break;
 case 2: 
 return 'third-price';
 break;
 }
 };
 module.exports.style = indexof;
 </wxs>

view

 <view class="weui-badge {{rank.style(index)}}">{{index + 1}}</view>

補充:

vue與微信小程式的一些差異

#一.條件渲染

vue :使用v-if指令,v-else表示v-if的else區塊,v-else-if表示v-if 的「else-if 區塊」

 <p v-if="type === &#39;A&#39;">
  A
 </p>
 <p v-else-if="type === &#39;B&#39;">
  B
 </p>
 <p v-else-if="type === &#39;C&#39;">
  C
 </p>
 <p v-else>
  Not A/B/C
 </p>

微信小程式:使用wx:if, wx:else表示wx:if的else區塊,wx:elif表示wx:if的"else-if"區塊

<view wx:if="{{length > 5}}"> 1 </view>
<view wx:elif="{{length > 2}}"> 2 </view>
<view wx:else> 3 </view>

二.顯示隱藏元素

VUE:v-show="..."

微信小程式:hidden="{{...}}"

#三.綁定class

vue:全用v- bind,或簡寫為:bind,和本有的class分開寫

<p class="test" v-bind:class="{ active: isActive }"></p>

微信小程式:

<view class="test {{isActive ? &#39;active&#39;:&#39;&#39; }}"></view>

四.事件處理

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="clickMe">点击我</button>
<button catchtap="clickMe">点击我</button> //阻止事件冒泡

五.綁定值

VUE:vue動態綁定一個變數的值為元素的某個屬性的時候,會在變數前面加上冒號:,例:<img :src="imgSrc"/>

微信小程式:綁定某個變數的值為元素屬性時,會用兩個大括號括起來。例:<image src="{{imgSrc}}"></image>

六.綁定事件傳參

#VUE:vue綁定事件的函數傳參數時,可以把參數寫在函數後面的括號裡

<p @click="changeTab(1)">哈哈</p>

微信小程式:微信小程式的事件我試過只能傳函數名,至於函數值,可以綁定到元素中,在函數中取得

<view data-tab="1" catchtap="changeTab">哈哈</view>

js:

changeTab(e){
  var _tab = e.currentTarget.dataset.tab; 
}

七.設定值

VUE:設定test的值可以用,this.test = true;取得test的值可以用this.test.

微信小程式:設定test的值要用this.setData({test:true});取得test的值用this.data.test

相信看了本文案例你已經掌握了方法,更多精彩請關注php中文網其它相關文章!

推薦閱讀:

Angular中如何呼叫第三方函式庫

Angular ng-animate與ng-cookies如何在項目內使用

以上是微信小程式內怎樣動態綁定類別名的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn