国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 熱點 > 微信 > 正文

微信小程序自定義組件

2024-07-22 01:16:58
字體:
來源:轉載
供稿:網友

前言

最近接觸微信小程序,再次之前公司用的前端框架是vue ,然后對比發現,開發小程序是各種限制,對于開發者非常不友好。各種槽點太多,完全吐槽不過來,所以在此不多說,打算下次專門寫一篇文章吐槽一下。本次主要分享下小程序自定義組件的一點思路,小程序官方提供的框架比較簡陋,原始,可復用較差,沒有實現自定義組件的功能,這讓很多使用vue ,react前端開發非常難受。網上存在各種吐槽,也有分享實現自定義組件的方法,但是要么過于復雜,要么是微信小程序升級之后就不兼容,反正是各種坑你沒商量。在這分享下本人在項目中是如何實現的,歡迎指正批評,互相學習。

toast自定義組件實現

這里用最簡單的toast組件為例子 官方框架只提供了 頁面模板功能 : WXML提供模板(template),可以在模板中定義代碼片段,然后在不同的地方調用。 但是這個功能不 支持js,樣式封裝,需要在對應的頁面做處理,且模板還有自己的作用域,需要使用data傳入。 把功能封裝成獨立的組件,需要和頁面獨立,在使用時將組件掛載到對應的頁面,所以組件需要傳入頁面this(Page)對象 ,實現代碼如下

目錄結構

|------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 必傳 提示內容 * showTime 非必傳 顯示時間秒*/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引用頁面模板

2、js 文件引用 toast.js

import { toast } from '../../../project/component/toast/toast.js'            
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 临泉县| 芒康县| 六盘水市| 运城市| 淮北市| 彭州市| 昌平区| 博客| 张北县| 建始县| 琼结县| 巴青县| 松滋市| 怀安县| 潮州市| 龙井市| 东光县| 绵竹市| 丰台区| 三门县| 贺州市| 彩票| 禄劝| 肥乡县| 宁波市| 扶风县| 麻栗坡县| 郁南县| 甘南县| 紫云| 措勤县| 萍乡市| 呼伦贝尔市| 松江区| 格尔木市| 启东市| 高唐县| 阳东县| 广昌县| 中西区| 肃北|