全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

微信小程序自定义组件

前言

最近接触微信小程序,再次之前公司用的前端框架是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'

3、调用

toast(this, '填写详细信息')

改进及更多扩展

实际项目中会有toast confirm loading ···等多个通用组件 ,还有大量的业务组件,我们可以把js都引入到一个js文件中,然后在页面加载的时候(onLoad方法)中注册this(page),这样只需要注册一次便可以使用所有的组件,如

toast(this,'填写详细信息'')

变成

toast('填写详细信息'')

同样的思路,我们可以实现类似vue中混合(mixin)的功能,在业务复杂的项目中,大大提高代码的可复用 性和可维护性。

公司小程序只有我一个人开发,不存在多人协作开发小程序的情况,在这方面下的功夫不多。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# 微信小程序  # 自定义组件  # 微信小程序动态的显示或隐藏控件的方法(两种方法)  # 微信小程序点击控件修改样式实例详解  # 微信小程序 实现动态显示和隐藏某个控件  # 微信小程序 点击控件后选中其它反选实例详解  # 微信小程序 input输入框控件详解及实例(多种示例)  # 微信小程序 视图容器组件的详解及实例代码  # 微信小程序 自己制作小组件实例详解  # 微信小程序 基础组件与导航组件详细介绍  # 微信小程序实现动态显示和隐藏某个控件功能示例  # 自定义  # 在这  # 自己的  # 复用  # 也有  # 会有  # 太多  # 多个  # 在此  # 就不  # 不多  # 我们可以  # 便可  # 不存在  # 只需要  # 你没  # 可以实现  # 多说  # 只提供  # 最简单 


相关文章: 安徽网站建设与外贸建站服务专业定制方案  武汉外贸网站制作公司,现在武汉外贸前景怎么样啊?  如何快速重置建站主机并恢复默认配置?  实现虚拟支付需哪些建站技术支撑?  广州网站制作的公司,现在专门做网站的公司有没有哪几家是比较好的,性价比高,模板也多的?  如何在Golang中引入测试模块_Golang测试包导入与使用实践  Python如何创建带属性的XML节点  香港服务器网站卡顿?如何解决网络延迟与负载问题?  建站之星CMS五站合一模板配置与SEO优化指南  表情包在线制作网站免费,表情包怎么弄?  IOS倒计时设置UIButton标题title的抖动问题  小程序网站制作需要准备什么资料,如何制作小程序?  完全自定义免费建站平台:主题模板在线生成一站式服务  ,网页ppt怎么弄成自己的ppt?  手机怎么制作网站教程步骤,手机怎么做自己的网页链接?  建站之星如何快速解决建站难题?  如何在橙子建站中快速调整背景颜色?  太平洋网站制作公司,网络用语太平洋是什么意思?  如何通过云梦建站系统实现SEO快速优化?  简历在线制作网站免费版,如何创建个人简历?  制作网站怎么制作,*游戏网站怎么搭建?  上海网站制作网站建设公司,建筑电工证网上查询系统入口?  如何选择域名并搭建高效网站?  如何在七牛云存储上搭建网站并设置自定义域名?  桂林网站制作公司有哪些,桂林马拉松怎么报名?  广东企业建站网站优化与SEO营销核心策略指南  已有域名如何免费搭建网站?  股票网站制作软件,网上股票怎么开户?  微信网站制作公司有哪些,民生银行办理公司开户怎么在微信网页上查询进度?  红河网站制作公司,红河事业单位身份证如何上传?  学校建站服务器如何选型才能满足性能需求?  建站主机选购指南与交易推荐:核心配置解析  如何自定义建站之星网站的导航菜单样式?  建站主机空间推荐 高性价比配置与快速部署方案解析  Bpmn 2.0的XML文件怎么画流程图  一键制作网站软件下载安装,一键自动采集网页文档制作步骤?  如何破解联通资金短缺导致的基站建设难题?  ,怎么用自己头像做动态表情包?  建站主机选哪家性价比最高?  如何登录建站主机?访问步骤全解析  如何选择高性价比服务器搭建个人网站?  建站10G流量真的够用吗?如何应对访问高峰?  如何在阿里云域名上完成建站全流程?  建站之星代理费用多少?最新价格详情介绍  常州自助建站:操作简便模板丰富,企业个人快速搭建网站  关于BootStrap modal 在IOS9中不能弹出的解决方法(IOS 9 bootstrap modal ios 9 noticework)  深圳网站制作费用多少钱,读秀,深圳文献港这样的网站很多只提供网上试读,但有些人只要提供试读的文章就能全篇下载,这个是怎么弄的?  如何通过VPS搭建网站快速盈利?  南京做网站制作公司,南京哈发网络有限公司,公司怎么样,做网页美工DIV+CSS待遇怎么样?  三星网站视频制作教程下载,三星w23网页如何全屏? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。