一、项目、配置简介
1、目录文件介绍
data:image/s3,"s3://crabby-images/53c47/53c475b5928d68a8807b82ad8e5612dfad0122b9" alt=""
data:image/s3,"s3://crabby-images/deb38/deb38afae0a4c292f722a0797f6f1a88a093e291" alt=""
data:image/s3,"s3://crabby-images/b5e00/b5e00bf32c3aef7ce0f94fe7e859c98683d96ba0" alt=""
二、小程序框架:逻辑层、视图层
1、wxml设置数据和js修改数据 this.setData()
data:image/s3,"s3://crabby-images/5344c/5344c597da78bf95bc5b60fedb0384304fdd21f3" alt=""
2、点击事件 bindtap
wxml
html
<view> Hello {{name}}! </view>
<button bindtap="changeName"> Click me! </button>
</view>
js
java
Page({
changeName(){
this.setData({
name:'MINA'
})
}
})
data:image/s3,"s3://crabby-images/875d6/875d6b9cf7ec1739eb732744d5c88732782a6138" alt=""
3、注册小程序
data:image/s3,"s3://crabby-images/d058d/d058d65dfeb15d39cca8572dae55a74976f63f63" alt=""
4、behaviors
data:image/s3,"s3://crabby-images/5dd3a/5dd3a57b6c5d9f9ff59e3a92d064d2f9df04a35a" alt=""
5、Componet控件
data:image/s3,"s3://crabby-images/2bf68/2bf68accb20c0d1677ecaf3701e539939e132530" alt=""
6、路由;页面跳转
data:image/s3,"s3://crabby-images/64e1a/64e1affdec10abfc132caf326646d8679ffe6faf" alt=""
data:image/s3,"s3://crabby-images/235c6/235c612bca662995880ae800d998d56e17354ab0" alt=""
7、 模块化 module.exports
data:image/s3,"s3://crabby-images/a0ee3/a0ee35c3e85b6fadf1eef96e5b83351494737c4e" alt=""
8、列表渲染:for循环 wx:for
html
<view wx:for="{{array}}">{{item}}</view>
data:image/s3,"s3://crabby-images/e825e/e825e5f2d3e64d3f91facd31b15086a8b984de9e" alt=""
data:image/s3,"s3://crabby-images/c1e40/c1e40b6aaa060c888b455f81063080e90a8ecce3" alt=""
9、条件渲染 wx:if wx:elif wx:else
data:image/s3,"s3://crabby-images/a0bd2/a0bd27a788b84517a5571af6d353c2f70dc47965" alt=""
data:image/s3,"s3://crabby-images/3bc55/3bc55b82e4f0cd21320812065af58e9e8fb0089d" alt=""
10、模版 <template>
html
<template name="staffName">
<view>
firstName:{{firstName}} , lastName:{{lastName}}
</view>
</template>
<template is="staffName" data="{{...staffA}}"></template>
<template is="staffName" data="{{...staffB}}"></template>
<template is="staffName" data="{{...staffC}}"></template>
data:image/s3,"s3://crabby-images/71ecc/71eccda6ba7a70bbc39be68a02d793d13f56e050" alt=""
data:image/s3,"s3://crabby-images/b7784/b7784d5fe4e008d0804455231c4f76c23cf81347" alt=""
-
<template name="staffName"> staffName 模板名 , firstName:{{firstName}} , lastName:{{lastName}} 模版输出内容: firstName:xxx , lastName:xxx
-
is="staffName" is说明模版是哪一个 data中 ... 不能少
3)js中 按照模版输出语句 传入参数即可
11、wxss(css) 布局控件属性:宽高、边距、颜色、大小等 , 控件中引用class="xxx"
css
/* pages/test/test.wxss */
.normalPadding{
margin-top: 10px;
margin-left: 50px;
color: #d61aaa;
}
html
<text class="normalPadding">WXSS样式测试</text>
data:image/s3,"s3://crabby-images/7f875/7f875f46cdb47ac938aa029b1ce6a70427bd5290" alt=""
12、选择器
data:image/s3,"s3://crabby-images/4ebd1/4ebd18a06abf5a10b9776c40d8efbc61384b09d5" alt=""
13、事件绑定
1)bindtap 不拦截传递
data:image/s3,"s3://crabby-images/37c46/37c46b25239ac36a591d211f08e11683fc830b17" alt=""
- catchtap 拦截传递
data:image/s3,"s3://crabby-images/ac5b1/ac5b10cee0fe0318c671211d08cbf8e8ff4383cc" alt=""
3)mut-bind 互斥事件绑定
data:image/s3,"s3://crabby-images/f1fc0/f1fc0fb210633baad6fd07f7f702597e73aa16f7" alt=""
14、事件对象
data:image/s3,"s3://crabby-images/bb859/bb8592fb670f2595f16547f4feb6887dcacd6316" alt=""
data:image/s3,"s3://crabby-images/18d6a/18d6a1ba08e4d15041d612dd911d27baa6a471b1" alt=""
data:image/s3,"s3://crabby-images/13132/1313286f8dae1c42a59d58662778d4f025bdabf6" alt=""
15、数据双向绑定 input :多用于输入框
data:image/s3,"s3://crabby-images/b6389/b63896d3a23e6657a5b3528021ff4c6fdc5179da" alt=""
16、组件属性
data:image/s3,"s3://crabby-images/53968/53968dcf120d49a966918d243802400ff235e739" alt=""
data:image/s3,"s3://crabby-images/b0639/b06395bfc278d6fa89db39df30f9d5a70ddd8877" alt=""
17、获取界面节点信息
data:image/s3,"s3://crabby-images/48540/485402bc9408acfb3de76ea99ec484934328c3ad" alt=""
data:image/s3,"s3://crabby-images/11d65/11d65ed8f0c143de8b5880fc79a988feb9c51b03" alt=""
18、小程序随屏幕旋转
data:image/s3,"s3://crabby-images/2b5c1/2b5c1c4d1878974317c7faceb10da03404d699ea" alt=""
data:image/s3,"s3://crabby-images/29b5d/29b5d3a2030f63b414c0b34ce6f31859bc112401" alt=""
19、动画
data:image/s3,"s3://crabby-images/bf36a/bf36a524021acc04b0277ab509cbdcaf081bc8c1" alt=""
data:image/s3,"s3://crabby-images/98607/98607d97d409689d04ff53509922249bd6fba5ee" alt=""
三、小程序运行时
1、小程序生命周期
data:image/s3,"s3://crabby-images/8608a/8608ae928bc924235c0f87b4d6a19e09dfbe4851" alt=""
2、重启策略
data:image/s3,"s3://crabby-images/7c42c/7c42cf82ed6d9dcb5e6c2f265798f86024d102b5" alt=""
3、被销毁数据保存
data:image/s3,"s3://crabby-images/25641/25641e6ab4da20ef17e40bbb6c716fdd070ad5c1" alt=""
data:image/s3,"s3://crabby-images/6d3a5/6d3a52610e672ad947e2bd13f6bc9ca578cfc071" alt=""
4、小程序手动更新
data:image/s3,"s3://crabby-images/d71b0/d71b04ca423de68be7fa1b83cae5440bbd8cea13" alt=""
四、自定义组件
1、创建自定义组件
data:image/s3,"s3://crabby-images/91382/913827c1d611b4fff56d7fa141fac78d1f2821c1" alt=""
新建组件文件夹;新建component;
data:image/s3,"s3://crabby-images/5e769/5e7693a988f2e48fea4b2b7bc382f516e6de1b93" alt=""
data:image/s3,"s3://crabby-images/889c6/889c643f53e5691f0a321ed17a9436adcd111ee1" alt=""
data:image/s3,"s3://crabby-images/b3208/b3208c0c79da17ed94c5fe935017d9d3687a708b" alt=""
data:image/s3,"s3://crabby-images/947bb/947bbfec1281eefa3560e68a2f21bcfb40952910" alt=""
其他文件json中引用
data:image/s3,"s3://crabby-images/f9a7d/f9a7d7cb749fbfd15dfd7adbc1f55eeb57d29674" alt=""
布局中使用
data:image/s3,"s3://crabby-images/2e832/2e832c32926c331be880765fd3f8a8e1cbbcb626" alt=""
data:image/s3,"s3://crabby-images/7f098/7f09876dd3f4a366aa7f84f237f7b8da636a4256" alt=""
data:image/s3,"s3://crabby-images/887bc/887bcf605c228451cef97d572e2d74da46dc0fe8" alt=""
2、组件模版
单slot 节点
data:image/s3,"s3://crabby-images/19470/1947071600e0369b0c83b0019ae3f19e4fe42438" alt=""
data:image/s3,"s3://crabby-images/b4e3a/b4e3ac9dfb2e14963e7b2090934a3abb28f86581" alt=""
data:image/s3,"s3://crabby-images/be3fb/be3fba83f8505795f989f09df40404af72e1e923" alt=""
多slot节点 用 name区分
data:image/s3,"s3://crabby-images/55f95/55f951b52070d2f095d0e7c8bc74ee0eb9d70cb0" alt=""
data:image/s3,"s3://crabby-images/6e80d/6e80d0ab2625b477642e5fc9e1f262ca27a2f134" alt=""
data:image/s3,"s3://crabby-images/27a56/27a56a12715f253b26ef31aa5a4159eabb83a664" alt=""
3、组件样式
data:image/s3,"s3://crabby-images/fb4b9/fb4b9fbb6e89201a77796804bcadc3d8e293e81a" alt=""
data:image/s3,"s3://crabby-images/4ed79/4ed79410eb42ff1ad56e7c90ee189da42577593f" alt=""
data:image/s3,"s3://crabby-images/53832/538327bf01a8aee03dab635e1195663e7208cb40" alt=""
data:image/s3,"s3://crabby-images/2f650/2f650d349f3922dd2c6e7f1956eaaec5ec302585" alt=""
4、组件样式隔离
data:image/s3,"s3://crabby-images/3bf8a/3bf8abe69d553c62d12019b6e2621ab88d6b008f" alt=""
data:image/s3,"s3://crabby-images/0e835/0e8355d50a80836cf6c73356ac7aabceed446145" alt=""
data:image/s3,"s3://crabby-images/0cf1e/0cf1ec21f292b81f18e38eff987e1e543aaefdbb" alt=""
data:image/s3,"s3://crabby-images/243f0/243f003a6b97cb0a5e1a6d105e7fcfef4018637d" alt=""
data:image/s3,"s3://crabby-images/ef8e5/ef8e508ccd09b50566e484f7a72a306107d0d8bf" alt=""
5、外部样式引用
作用是统一样式,所有组件或page都可以直接使用,方便修改
新建外部组件
data:image/s3,"s3://crabby-images/9c0eb/9c0eb5b5b322271ceb83fcd70bb097bc28703377" alt=""
wxss 定义外部样式
data:image/s3,"s3://crabby-images/9e92a/9e92ad9a35cf1f5857519d0ab5575de56c7bdb7c" alt=""
需要使用的自定义组件中 添加外部样式
data:image/s3,"s3://crabby-images/f9134/f913437afc6b910770e54f6bece1b4b00a909446" alt=""
自定义组件使用外部样式进行布局
data:image/s3,"s3://crabby-images/07b7d/07b7d32dc9637f114c4d8d07d1370f1f7cb944a3" alt=""
Page中使用组件,并且使用外部样式
data:image/s3,"s3://crabby-images/de43f/de43ff64611078401138fc9ac24aeb78abc523f3" alt=""
到这儿你可能发现外部样式并没有效果,赋值未成功,需要在app.wxss中引用你使用到的外部样式
data:image/s3,"s3://crabby-images/6ab45/6ab458c2ae1afe2de5ae2f3db92aa11df9cd2ac0" alt=""
data:image/s3,"s3://crabby-images/0d918/0d918984071ca68164695aeb4902b09c25d53f1c" alt=""
6、引用页面 '~ '或父组件样式 '^'
data:image/s3,"s3://crabby-images/9c48c/9c48cb7493d0caf7a27f020577a1135fc9c4ea1b" alt=""
7、Component 构造器
Component 构造器可用于定义组件,调用 Component 构造器时可以指定组件的属性、数据、方法等。
javascript
Component({
behaviors: [],
properties: {
myProperty: { // 属性名
type: String,
value: ''
},
myProperty2: String // 简化的定义方式
},
data: {}, // 私有数据,可用于模板渲染
lifetimes: {
// 生命周期函数,可以为函数,或一个在methods段中定义的方法名
attached: function () { },
moved: function () { },
detached: function () { },
},
// 生命周期函数,可以为函数,或一个在methods段中定义的方法名
attached: function () { }, // 此处attached的声明会被lifetimes字段中的声明覆盖
ready: function() { },
pageLifetimes: {
// 组件所在页面的生命周期函数
show: function () { },
hide: function () { },
resize: function () { },
},
methods: {
onMyButtonTap: function(){
this.setData({
// 更新属性和数据的方法与更新页面数据的方法类似
})
},
// 内部方法建议以下划线开头
_myPrivateMethod: function(){
// 这里将 data.A[0].B 设为 'myPrivateData'
this.setData({
'A[0].B': 'myPrivateData'
})
},
_propertyChange: function(newVal, oldVal) {
}
}
})
data:image/s3,"s3://crabby-images/1bb43/1bb4336c1b17a0e98716b1732c6eb6bfbe0e2ff2" alt=""
8、组件间通信与事件 triggerEvent
data:image/s3,"s3://crabby-images/ee508/ee508acf2311f422ee182a2417fb161c4442c196" alt=""
为自定义组件设置触发事件
data:image/s3,"s3://crabby-images/e35e7/e35e7f893ef11da973e7c4ac576413bde77dd422" alt=""
data:image/s3,"s3://crabby-images/34879/34879abafc10296d7ae7fa40a4886039d6cfee79" alt=""
page中使用自定义控件并监听'myevent'事件
data:image/s3,"s3://crabby-images/f5bfe/f5bfe3e3c15f6be3a3b3186bec4427463b6d6bbb" alt=""
page中处理事件响应
data:image/s3,"s3://crabby-images/a2afb/a2afb475df60177a30a04953a56deff2275c5c06" alt=""
data:image/s3,"s3://crabby-images/6c956/6c9561bd33920c7c0cc8899a4ce8d1df78ebd7c1" alt=""
data:image/s3,"s3://crabby-images/84232/84232da3e3666e5653f82b9cfdbfcea8651c72b9" alt=""