您好,登錄后才能下訂單哦!
小編給大家分享一下微信小程序怎么制作五星評分效果,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!
微信小程序五星評分效果實現(xiàn)代碼
很多做過電商項目的朋友會經(jīng)常用到評分的功能,我這里正好寫了一個例子,發(fā)出來分享一下:
我寫的是5分滿分制的,首先,準備3個圖片,
,像這樣的,分別代表分數(shù)為0,0.5,1 時的狀態(tài),
效果圖:(以3.5為例)
然后上代碼:
js:
function pingfenxing(pingfen){ var that=this, //這里是圖片的路徑,自己需要改 data={ ling:"img/pingfen0.png", zheng:"img/pingfen2.png", ban:"img/pingfen1.png" }, nums=[];//這里是返回圖片排列的順序的數(shù)組,這里要注意在頁面使用的時候圖片的路徑,不過使用網(wǎng)絡(luò)圖片無所謂 if((pingfen/0.5)%2==0){//如果評分為整數(shù),如4.0、5.0 for(var i=0;i<5;i++){ if(i<pingfen){ nums.push(data.zheng); }else{ nums.push(data.ling); } } }else{//評分不為整數(shù),如3.5、2.5 for(var i=0;i<5;i++){ if(i<pingfen-0.5){ nums.push(data.zheng);//先把整數(shù)分離出來,如:3.5,這里就是先把3分離出來,把代表1的圖片放進去 }else if(i==(pingfen-0.5)){ nums.push(data.ban);//把小數(shù)的部分分離出來,如:3.5里的0.5,把代表0.5的圖片放進去 }else{ nums.push(data.ling);//然后剩下的就是沒有滿的用代表0的圖片放進去,如:3.5,里面放進去了3個代表1的圖片,然后放入了1個代表0.5的圖片,最后還剩一個圖片的位置,這時候就放代表0的圖片 } } } return num; } module.exports = { pingfen:pingfenxing }
WXML代碼:
<view class="pingfen"> <block wx:for="{{item.pingfenpic}}" wx:key="{{item.id}}" wx:for-item="pingfen"> <image class="img" src="{{pingfen}}"></image> </block> <text data-pingfen="{{item.pingfen}}" >{{item.pingfen}}</text> </view>
使用這個功能的頁面的JS代碼:
var pingxin=require("../../utils/pingxing.js"); Page({ data:{ tuangou:tuangou}//我這里是在頁面加載的時候先從后臺獲取數(shù)據(jù),把數(shù)據(jù)的值賦值給tuangou,然后遍歷將數(shù)據(jù)里面的參數(shù)拿出來,然后再把相應(yīng)的評分中的圖片排列順序放到這條數(shù)據(jù)中的pingfenpic中保存,然后在頁面中渲染即可 onLoad:function(options){ console.log('onLoad'); var that=this; // 頁面初始化 options為頁面跳轉(zhuǎn)所帶來的參數(shù) wx.request({ url: 'https://wxapp.com/tuangou',//這里是你請求數(shù)據(jù)的接口地址,自己填寫 data: {}, method: 'GET', success: function(res){ // success console.log(res.data.tuangou); let tuangou=res.data.tuangou; for(let i=0;i<tuangou.length;i++){ tuangou[i].pingfenpic=pingxin.pingfen(parseFloat(tuangou[i].pingfen));//使用函數(shù)將評分變?yōu)閳D片排列的數(shù)組,這里要注意,如果評分傳過來的是字符串 需要將它變?yōu)閿?shù)字 } that.setData({ tuangou:tuangou }); console.log(that.data.tuangou); }, fail: function() { // fail }, complete: function() { // complete } }); } });
看完了這篇文章,相信你對“微信小程序怎么制作五星評分效果”有了一定的了解,如果想了解更多相關(guān)知識,歡迎關(guān)注億速云行業(yè)資訊頻道,感謝各位的閱讀!
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。