一 小程序提供了很多api和基础组件,但为减少代码的复杂度和提高复用率,小程序也提供了自己的代码复用机制:
小程序复用:页面模版(template),组件模版(component,使用时用标签的形式)。
这两种模版的写法和之前页面的写法是一样的,都有四个文件 wxml,js,wxss, json
二我们在使用基础组件时比如 <view bindtap="" catchtap="" data-name="" id="" class="" ></view> 总会写事件和属性值,
自定义组件也一样需要有自己的属性和事件,
属性分内部属性和外部属性,这两种属性共同设置了组件的样式。内部属性可以理解为手机的预装软件。外部属性可以理解为手机的应用商店,可以自己手动管理。当然我们也会提供接口供使用者来修改内部属性。
三,生命周期:
组件也有生命周期函数,和页面一样。
页面有:onload onready onshow onhide onunload
组件有:created attached ready detached move
新建component组件:
四,自定义组件,这是官方提供的例子
Component({ //自定义组件的专有形式,如page页面的page({}),app文件的App({})
behaviors: [],
properties: {
myProperty: { // 属性名
type: String, // 类型(必填),目前接受的类型包括:String, Number, Boolean, Object, Array, null(表示任意类型)
value: '', // 属性初始值(可选),如果未指定则会根据类型选择一个
observer: function(newVal, oldVal){} // 属性被改变时执行的函数(可选),也可以写成在methods段中定义的方法名字符串, 如:'_propertyChange'
},
myProperty2: String // 简化的定义方式
},
data: {}, // 私有数据,可用于模版渲染
// 生命周期函数,可以为函数,或一个在methods段中定义的方法名
attached: function(){},
moved: function(){},
detached: function(){},
methods: {
onMyButtonTap: function(){
this.setData({
// 更新属性和数据的方法与更新页面数据的方法类似
})
},
_myPrivateMethod: function(){
// 内部方法建议以下划线开头
this.replaceDataOnPath(['A', 0, 'B'], 'myPrivateData') // 这里将 data.A[0].B 设为 'myPrivateData'
this.applyDataUpdates()
},
_propertyChange: function(newVal, oldVal) {
}
}
})
在使用组件的页面的json文件中配置
{ useComponents:{"自定义组件名字":"组件的绝对路径"}} 如{ useComponents:{"p":"../page/page"}}
需求:自定义组件中放其他的基础组件。
方法:在自定义组件的wxml文件中使用<slot name="">标签
自定义组件:<slot name="test"></slot>,将此标签放入想要安置的位置。
引用页面 :<view style="background: _ _ _" slot="test"></view>//如果想要设置样式的话写在<slot>标签中是无效的。
组件不论是自定义组件还是基础组件,都有自己的属性,事件。
注意:如果组件wxml文件中的slot标签中写了name属性,那么就必须在组件的js文件中写上options:{multipleSlots:true},不然不起作用。
小程序工具提供多类型商城/门店小程序制作,可视化编辑 1秒生成5步上线。通过拖拽、拼接模块布局小程序商城页面,所看即所得,只需要美工就能做出精美商城。更多小程序商店请查看:小程序商店
KESION 科汛软件
KESION 科汛软件是国内领先的在线教育软件及私域社交电商软件服务提供商,长期专注于为企业提供在线教育软件及社交电商SaaS平台解决方案。
公司核心产品云开店SaaS社交电商服务平台、在线教育SaaS服务平台、教育企业数字化SaaS云平台、企微营销助手、私有化独立部署品牌网校和在线教育咨询等。KESION 不断通过技术创新,提供产品和服务,助力企业向数字化转型,通过科技驱动商业革新,让商业变得更智慧!
1.小程序的生命周期App.js App() 必须在 app.js 中注册,且不能注册多个。所以App()方法在一个小程序中有且仅有一个。 App() 函数用来注册一个小程序。接受一个 object
随着小程序成为大家争先恐后的一大热门,很多商家和企业都期待着小程序能够给自己带来财富,而小程序注册方面也成为一大热点。...