摘要:組件化開發(fā)小程序在未出現(xiàn)組件之前,要重用的話,只能簡單復制粗暴黏貼組件化開發(fā)的優(yōu)勢可復用代碼分離,可維護更重要定義組件先創(chuàng)建文件夾用于存放組件,然后再創(chuàng)建組件文件夾注意組件的文件名并不是組件名,而頁面文件名是頁面名,組件名是引用時才確定的引
組件化開發(fā)
小程序在未出現(xiàn)組件之前,要重用的話,只能簡單(復制)粗暴(黏貼) 組件化開發(fā)的優(yōu)勢: 1、可復用(wxml/wxss/js) 2、代碼分離,可維護(更重要)
定義組件
先創(chuàng)建components文件夾:用于存放組件,然后再創(chuàng)建組件文件夾
注意:組件的文件名并不是組件名,而頁面文件名是頁面名,組件名是引用時才確定的
引入與使用組件
頁面先引用后使用 在頁面的配置文件(.json)中引入組件 { "usingComponents": { "組件名":"/components/tab/index" } } 在頁面中使用組件 <組件名 />
全局樣式的繼承
(定義在app.wxss中)全局樣式,頁面是全部繼承的,而自定義組件只是部分繼承 **全局樣式一般設置字體和字體大小
只支持font、color樣式組件可以繼承,其他樣式不繼承
組件設計原則
1、盡量不要留空白間距
組件事件與綁定
1、給組件綁定事件(.wxml)components/love/index.wxml 2、實現(xiàn)組件事件處理函數(shù)(.js) methods: { tapLove(ev){ console.log(ev); } }
組件data與properties的區(qū)別
頁面只有data,而組件有data和properties
data與properties中的數(shù)據(jù)都可以在組件中進行單向數(shù)據(jù)綁定 原理: 與頁面其實一樣,小程序編譯后,data與properties將會和并成一個data (如果data中與peoperties中有重名數(shù)據(jù),優(yōu)先peoperties) 所以進行動態(tài)數(shù)據(jù)綁定還是使用this.setData()方法 使用原則: data:內(nèi)部數(shù)據(jù) properties:外部數(shù)據(jù)(頁面調(diào)用組件,傳遞進來的數(shù)據(jù),不傳遞就使用默認值)
組件獲取外部數(shù)據(jù)的途徑
1、通過組件屬性(接收參數(shù),而頁面是通過onLoad(options)接收) 2、通過getApp().globalData.xxx 獲取全局數(shù)據(jù) 3、通過緩存獲取全局數(shù)據(jù)
組件與業(yè)務邏輯
到底業(yè)務邏輯是放在組件中還是該放在頁面中?
由于組件是可復用的,每個頁面都可以使用同一個組件,此時需要看清楚這個業(yè)務邏輯是 **共有** 還是 **個性** 的 共有的必須寫在組件內(nèi)(例如樣式) 個性的必須寫在頁面中(例如請求URL)
observer函數(shù)
組件的屬性值被更改時的響應函數(shù),注意如果在observer函數(shù)中使用this.setData()修改自身屬性可能發(fā)生死循環(huán)導致內(nèi)存溢出插件開發(fā) 事件與事件處理
事件作用
1、事件是視圖層到邏輯層的通訊方式(小程序內(nèi)置事件) 2、組件與頁面的通訊(自定義事件)
小程序內(nèi)置事件
長按事件:longpress 點擊事件:tap 觸摸動作開始:touchstart 觸摸后移動:touchmove 觸摸動作結(jié)束:touchend 還有各個組件上都有各自特定的事件
事件綁定(綁定事件處理函數(shù))
有2種方式:bind、catch 無論是內(nèi)置還是自定義事件,都是使用這種方式
寫法: bind:tap/bind:touchmove catch:tap/catch:touchmove bind與catch的區(qū)別 bind事件綁定不會阻止冒泡事件向上冒泡,catch事件綁定可以阻止冒泡事件向上冒泡。
事件分類
事件分為頁面事件和組件事件 頁面事件主要寫在頁面中,在頁面wxml內(nèi)組件先綁定事件bind:tap,在js中再綁定事件處理函數(shù) 組件事件主要寫在組件中,在組件wxml內(nèi)組件先綁定事件bind:tap,在js中再綁定事件處理函數(shù) **頁面與組件在事件綁定和處理上是完全獨立的2個部分,互相沒有關聯(lián),也不能互換 **組件的事件可以冒泡到頁面上去
自定義事件激活及處理
// 自定義事件激活 this.triggerEvent("myevent", { param:"wutao" }, {}); // 第一個參數(shù):自定義事件名稱 // 第二個參數(shù):detail對象,自定義數(shù)據(jù)(傳參數(shù)) // 第三個參數(shù):觸發(fā)事件的選項 // 自定義事件處理:在頁面wxml的組件調(diào)用標簽處寫下如下代碼新布局
flex 新一代布局樣式,以前很難實現(xiàn)的布局,現(xiàn)在變簡單了
注意
1、元素本身不會因為display:flex而改變原本塊狀或行間特性 2、flex下的item元素會變成行間特性(原本塊狀特性改變)新單位
rpx 是小程序提供的一種自適應單位,與iphone6的尺寸是1:1,推薦設計稿以IPHONE6為原型
rpx 與 px 的區(qū)別是什么? 1、px不會自適應,無論什么機型,什么尺寸屏幕都是一個大小,有些字體不隨設備屏幕發(fā)生變化時使用px 2、rpx會自適應,根據(jù)機型發(fā)生相應改變Promise
串行請求(請求之間有依賴)
// 請求1 let req1 = new Promise((resolve, reject) => {}); // 請求2 let req2 = new Promise((resolve, reject) => {}); // 請求3 let req3 = new Promise((resolve, reject) => {}); // 要求執(zhí)行順序1、2、3 req1.then(res => { return req2; }).then(res => { return req3; });
并行請求(請求之間無依賴)
// 請求1 let req1 = new Promise((resolve, reject) => {}); // 請求2 let req2 = new Promise((resolve, reject) => {}); // 請求3 let req3 = new Promise((resolve, reject) => {}); // 要求并行執(zhí)行1、2、3 全部執(zhí)行完才執(zhí)行then中的回調(diào)函數(shù) Promise.all([req1, req2, req3]) .then(res => { }); // 要求并行執(zhí)行1、2、3 誰先執(zhí)行完就執(zhí)行then中的回調(diào)函數(shù) Promise.race([req1, req2, req3]) .then(res => { });
復合請求(既有串,也有并)
// 請求1 let req1 = new Promise((resolve, reject) => {}); // 請求2 let req2 = new Promise((resolve, reject) => {}); // 請求3 let req3 = new Promise((resolve, reject) => {}); let req4 = req1.then(res => { return req2; }) // 要求串行執(zhí)行1、2,與3并行執(zhí)行 Promise.all([req4, req3]) .then(res => { }); // 要求串行執(zhí)行1、2,與3并行執(zhí)行 Promise.race([req4,, req3]) .then(res => { });
then中的返回值
有4種情況:
1、返回Promise
2、返回具體的值
3、不返回
4、拋錯誤
無論2還是3,then都會返回一個Promise對象,而且對象中執(zhí)行resolve()方法 // 有返回值val resolve(val) // 不返回 resolve(undefined) **所以后面then都會執(zhí)行第一個函數(shù)
catch
catch為then的語法糖,它是then(null, rejection)的別名。 也就是說,catch也是then,它用于捕獲錯誤,它的參數(shù)也就是是then的第二個參數(shù)。 所以,假設catch中如果return 值的話,新的Promise對象也會是接受狀態(tài)。 var example = new Promise((fulfill, reject)=>{ let i = 1; reject(i); }) example .catch(()=>{console.log("我是第一個catch的回調(diào)函數(shù)"); return 1;}) .then(() =>{console.log("我是第一個then的回調(diào)函數(shù)"); throw Error }) .catch(()=>{console.log("我是第二個catch的回調(diào)函數(shù)")}) .then(() => {console.log("我是第二個then的回調(diào)函數(shù)")}) 調(diào)用reject函數(shù)后,promise變?yōu)閞ejected狀態(tài),故執(zhí)行第一個catch的回調(diào)函數(shù) 第一個catch的回調(diào)函數(shù)return 1,故執(zhí)行第一個then的回調(diào)函數(shù) 第一個then的回調(diào)函數(shù)throw Error,故執(zhí)行第二個catch的回調(diào)函數(shù) 第二個catch的回調(diào)函數(shù)ruturn undefined(如上文所言),故執(zhí)行第二個then的回調(diào)函數(shù)
鏈接描述
自定義登錄態(tài) 請求封裝 全局樣式全局樣式寫在:app.wxss
page{ color: #999999; font-size: 33rpx; }wxs頁面腳本
wxs作用
1、頁面渲染 2、數(shù)據(jù)處理 **wxs可以使用js代替,是否代替取決于個人決定 **wxs類似html頁面中內(nèi)嵌js代碼 **wxml文件內(nèi)部不能編寫js或調(diào)用js,如果想調(diào)用,必須使用wxs
wxs使用兩種方式
1、使用.wxs文件(可重用性更好) // /pages/tools.wxs var foo = ""hello world" from tools.wxs"; var bar = function (d) { return d; } module.exports = { FOO: foo, bar: bar, }; module.exports.msg = "some msg";注意事項{{tools.msg}} {{tools.bar(tools.FOO)}} 2、使用標簽(在wxml中) var msg = "hello world"; module.exports.message = msg; {{m1.message}}
1、CSS選擇器其實比官方文檔支持得更多 2、自定義組件的容器如果是行間元素,那么最外層元素會有最小高度21px,所以請盡量使用塊狀元素作為容器 3、wxml不但可以獲取對象的屬性,還可以獲取具體數(shù)組元素{{arr[0]}} {{obj.pro}}
文章版權歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/108325.html
摘要:微信小程序之獲取并解密用戶數(shù)據(jù)獲取后端掘金版權聲明本文為博主原創(chuàng)文章,若需轉(zhuǎn)載,請注明出處。正題開始,前端怎么學中文指南基本操作指南前端掘金作者緝熙簡介是推出的一個天挑戰(zhàn)。 使用 JS 在客戶端判斷當前網(wǎng)絡狀態(tài) - 前端 - 掘金 navigator.onLine 通過navigator.onLine判斷當前網(wǎng)絡狀態(tài): if(navigator.onLine){ ...}else{ ....
摘要:官網(wǎng)訪問官網(wǎng)更快閱讀全部免費分享課程出品全網(wǎng)最新微信小程序基于最新版開發(fā)者工具之初中級培訓教程分享。 iKcamp官網(wǎng):http://www.ikcamp.com 訪問官網(wǎng)更快閱讀全部免費分享課程:《iKcamp出品|全網(wǎng)最新|微信小程序|基于最新版1.0開發(fā)者工具之初中級培訓教程分享》。包含:文章、視頻、源代碼 showImg(https://segmentfault.com/i...
摘要:官網(wǎng)訪問官網(wǎng)更快閱讀全部免費分享課程出品全網(wǎng)最新微信小程序基于最新版開發(fā)者工具之初中級培訓教程分享。 iKcamp官網(wǎng):http://www.ikcamp.com 訪問官網(wǎng)更快閱讀全部免費分享課程:《iKcamp出品|全網(wǎng)最新|微信小程序|基于最新版1.0開發(fā)者工具之初中級培訓教程分享》。包含:文章、視頻、源代碼 showImg(https://segmentfault.com/i...
摘要:官網(wǎng)訪問官網(wǎng)更快閱讀全部免費分享課程出品全網(wǎng)最新微信小程序基于最新版開發(fā)者工具之初中級培訓教程分享。 iKcamp官網(wǎng):http://www.ikcamp.com 訪問官網(wǎng)更快閱讀全部免費分享課程:《iKcamp出品|全網(wǎng)最新|微信小程序|基于最新版1.0開發(fā)者工具之初中級培訓教程分享》。包含:文章、視頻、源代碼 showImg(https://segmentfault.com/i...
摘要:一個精巧易用的微信小程序開發(fā)輔助庫特點輕量小巧上手簡單支持和一樣優(yōu)雅的數(shù)據(jù)響應式支持數(shù)據(jù)自動更新更改緩存批量更新強大的網(wǎng)絡功能支持全局事件總線支持跨頁面?zhèn)髦抵С质纠こ淘谠创a目錄下用微信小程序開發(fā)工具打開即可。 Grace 一個精巧、易用的微信小程序開發(fā)輔助庫 Github: https://github.com/wendux/grace 特點 輕量、小巧、上手簡單 支持和Vue一樣...
閱讀 2190·2023-04-25 19:06
閱讀 1389·2021-11-17 09:33
閱讀 1777·2019-08-30 15:53
閱讀 2600·2019-08-30 14:20
閱讀 3554·2019-08-29 12:58
閱讀 3554·2019-08-26 13:27
閱讀 515·2019-08-26 12:23
閱讀 495·2019-08-26 12:22