微信小程序自定義組件
前言
最近接觸微信小程序,再次之前公司用的前端框架是vue ,然后對(duì)比發(fā)現(xiàn),開(kāi)發(fā)小程序是各種限制,對(duì)于開(kāi)發(fā)者非常不友好。各種槽點(diǎn)太多,完全吐槽不過(guò)來(lái),所以在此不多說(shuō),打算下次專門寫一篇文章吐槽一下。本次主要分享下小程序自定義組件的一點(diǎn)思路,小程序官方提供的框架比較簡(jiǎn)陋,原始,可復(fù)用較差,沒(méi)有實(shí)現(xiàn)自定義組件的功能,這讓很多使用vue ,react前端開(kāi)發(fā)非常難受。網(wǎng)上存在各種吐槽,也有分享實(shí)現(xiàn)自定義組件的方法,但是要么過(guò)于復(fù)雜,要么是微信小程序升級(jí)之后就不兼容,反正是各種坑你沒(méi)商量。在這分享下本人在項(xiàng)目中是如何實(shí)現(xiàn)的,歡迎指正批評(píng),互相學(xué)習(xí)。
toast自定義組件實(shí)現(xiàn)
- 這里用最簡(jiǎn)單的toast組件為例子
- 官方框架只提供了 頁(yè)面模板功能 : WXML提供模板(template),可以在模板中定義代碼片段,然后在不同的地方調(diào)用。
- 但是這個(gè)功能不 支持js,樣式封裝,需要在對(duì)應(yīng)的頁(yè)面做處理,且模板還有自己的作用域,需要使用data傳入。
- 把功能封裝成獨(dú)立的組件,需要和頁(yè)面獨(dú)立,在使用時(shí)將組件掛載到對(duì)應(yīng)的頁(yè)面,所以組件需要傳入頁(yè)面this(Page)對(duì)象 ,實(shí)現(xiàn)代碼如下
目錄結(jié)構(gòu)
|------components
|------toast
|------toast.js
|------toast.wxml
|------toast.wxss
代碼
toast.wxml
<template name='toast'>
<view class="s-toast" wx:if="{{msg}}">
<view class="s-toast-content">{{msg}}</view>
</view>
</template>
toast.js
/**
* toastMsg 必傳 提示內(nèi)容
* showTime 非必傳 顯示時(shí)間秒
*/
function toast(page, toastMsg, showTime) {
let timer
page.setData({ toastMsg })
showTime = showTime || toastMsg.length / 4
console.log(showTime)
clearTimeout(timer)
timer = setTimeout(() => {
page.setData({ toastMsg: '' })
clearTimeout(timer)
}, showTime * 1000)
}
module.exports = {
toast: toast,
}
toast.wxss
.s-toast-content {
position: fixed;
left: 50%;
color: #fff;
width: 500rpx;
bottom: 120rpx;
background: hsla(0,0%,7%,.7);
padding: 15rpx;
text-align: center;
-webkit-transform: translateX(-50%);
transform: translateX(-50%);
border-radius: 4rpx;
z-index: 6999;
}
使用方法
1、wxml引用頁(yè)面模板
2、js 文件引用 toast.js
import { toast } from '../../../project/component/toast/toast.js'
3、調(diào)用
toast(this, '填寫詳細(xì)信息')
改進(jìn)及更多擴(kuò)展
實(shí)際項(xiàng)目中會(huì)有toast confirm loading ···等多個(gè)通用組件 ,還有大量的業(yè)務(wù)組件,我們可以把js都引入到一個(gè)js文件中,然后在頁(yè)面加載的時(shí)候(onLoad方法)中注冊(cè)this(page),這樣只需要注冊(cè)一次便可以使用所有的組件,如
toast(this,'填寫詳細(xì)信息'')
變成
toast('填寫詳細(xì)信息'')
同樣的思路,我們可以實(shí)現(xiàn)類似vue中混合(mixin)的功能,在業(yè)務(wù)復(fù)雜的項(xiàng)目中,大大提高代碼的可復(fù)用 性和可維護(hù)性。
公司小程序只有我一個(gè)人開(kāi)發(fā),不存在多人協(xié)作開(kāi)發(fā)小程序的情況,在這方面下的功夫不多。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
JavaScript高級(jí)程序設(shè)計(jì) 讀書(shū)筆記之十 本地對(duì)象Date日期
本地對(duì)象Date日期操作實(shí)現(xiàn)方法,需要的朋友可以參考下2012-02-02
JavaScript實(shí)現(xiàn)簡(jiǎn)單抽獎(jiǎng)系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)簡(jiǎn)單抽獎(jiǎng)系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-03-03
談?wù)凧avaScript中super(props)的重要性
今天小編就為大家分享一篇關(guān)于談?wù)凧avaScript中super(props)的重要性,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧2019-02-02
原生JS實(shí)現(xiàn)的放大鏡效果實(shí)例代碼
放大鏡大家在各大網(wǎng)站都能見(jiàn)到,下面小編給大家分享一段 ,代碼是基于原生js實(shí)現(xiàn)的放大鏡效果,代碼簡(jiǎn)單易懂,非常不錯(cuò),具有參考借鑒價(jià)值,感興趣的朋友一起看看吧2016-10-10
指定區(qū)域的圖片自動(dòng)按比例縮小的js代碼(防止頁(yè)面被圖片撐破)
有時(shí)候我們更新的內(nèi)容,有很多的大圖片,就會(huì)導(dǎo)致頁(yè)面變形或看不到全圖。一般情況我們用css的max-width控制,但有些瀏覽器不支持,我們也可以用js做個(gè)補(bǔ)充2014-02-02
Javascript中實(shí)現(xiàn)String.startsWith和endsWith方法
這篇文章主要介紹了Javascript中實(shí)現(xiàn)String.startsWith和endsWith方法,這兩個(gè)很好用的方法在JS中沒(méi)有,本文就自己編碼實(shí)現(xiàn)了這兩個(gè)方法,需要的朋友可以參考下2015-06-06
JavaScript實(shí)現(xiàn)函數(shù)緩存及應(yīng)用場(chǎng)景
在JavaScript中,可以通過(guò)函數(shù)緩存來(lái)提高函數(shù)的執(zhí)行效率,本文就來(lái)介紹一下JavaScript實(shí)現(xiàn)函數(shù)緩存及應(yīng)用場(chǎng)景,具有一定的參考價(jià)值,感興趣的可以了解一下2024-01-01
javascript中的緩動(dòng)效果實(shí)現(xiàn)程序
javascript中的緩動(dòng)效果可以應(yīng)用于很多地方,比如距離位移上的變化:圖片的滾動(dòng)、焦點(diǎn)圖的輪轉(zhuǎn)切換,透明度上的變化:漸隱漸現(xiàn)。凡是存在運(yùn)動(dòng)的狀態(tài)都適用,下面以最基本的塊在容器內(nèi)從左到右滑動(dòng)為例,講下幾種不同的緩動(dòng)處理方式2012-12-12

