成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

微信小程序(新)必備知識

mengera88 / 2354人閱讀

摘要:組件化開發(fā)小程序在未出現(xiàn)組件之前,要重用的話,只能簡單復(fù)制粗暴黏貼組件化開發(fā)的優(yōu)勢可復(fù)用代碼分離,可維護(hù)更重要定義組件先創(chuàng)建文件夾用于存放組件,然后再創(chuàng)建組件文件夾注意組件的文件名并不是組件名,而頁面文件名是頁面名,組件名是引用時才確定的引

組件化開發(fā)
小程序在未出現(xiàn)組件之前,要重用的話,只能簡單(復(fù)制)粗暴(黏貼)

組件化開發(fā)的優(yōu)勢:
1、可復(fù)用(wxml/wxss/js)
2、代碼分離,可維護(hù)(更重要)

定義組件

先創(chuàng)建components文件夾:用于存放組件,然后再創(chuàng)建組件文件夾
注意組件的文件名并不是組件名,而頁面文件名是頁面名,組件名是引用時才確定的

引入與使用組件

頁面先引用后使用

在頁面的配置文件(.json)中引入組件
{
    "usingComponents": {
        "組件名":"/components/tab/index"
    }
}

在頁面中使用組件
<組件名 />

全局樣式的繼承

(定義在app.wxss中)全局樣式,頁面是全部繼承的,而自定義組件只是部分繼承

**全局樣式一般設(shè)置字體和字體大小
只支持font、color樣式組件可以繼承,其他樣式不繼承

組件設(shè)計原則

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ù)都可以在組件中進(jìn)行單向數(shù)據(jù)綁定

原理:
與頁面其實一樣,小程序編譯后,data與properties將會和并成一個data 
(如果data中與peoperties中有重名數(shù)據(jù),優(yōu)先peoperties)
所以進(jìn)行動態(tài)數(shù)據(jù)綁定還是使用this.setData()方法

使用原則:
data:內(nèi)部數(shù)據(jù)
properties:外部數(shù)據(jù)(頁面調(diào)用組件,傳遞進(jìn)來的數(shù)據(jù),不傳遞就使用默認(rèn)值)

組件獲取外部數(shù)據(jù)的途徑

1、通過組件屬性(接收參數(shù),而頁面是通過onLoad(options)接收)
2、通過getApp().globalData.xxx 獲取全局?jǐn)?shù)據(jù)
3、通過緩存獲取全局?jǐn)?shù)據(jù)

組件與業(yè)務(wù)邏輯

到底業(yè)務(wù)邏輯是放在組件中還是該放在頁面中?
由于組件是可復(fù)用的,每個頁面都可以使用同一個組件,此時需要看清楚這個業(yè)務(wù)邏輯是 **共有** 還是 **個性** 的
共有的必須寫在組件內(nèi)(例如樣式)
個性的必須寫在頁面中(例如請求URL)

observer函數(shù)

組件的屬性值被更改時的響應(yīng)函數(shù),注意如果在observer函數(shù)中使用this.setData()修改自身屬性可能發(fā)生死循環(huán)導(dǎo)致內(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個部分,互相沒有關(guān)聯(lián),也不能互換
**組件的事件可以冒泡到頁面上去

自定義事件激活及處理

// 自定義事件激活
this.triggerEvent("myevent", {
    param:"wutao"
}, {});
// 第一個參數(shù):自定義事件名稱
// 第二個參數(shù):detail對象,自定義數(shù)據(jù)(傳參數(shù))
// 第三個參數(shù):觸發(fā)事件的選項

// 自定義事件處理:在頁面wxml的組件調(diào)用標(biāo)簽處寫下如下代碼
新布局
flex 新一代布局樣式,以前很難實現(xiàn)的布局,現(xiàn)在變簡單了

注意

1、元素本身不會因為display:flex而改變原本塊狀或行間特性
2、flex下的item元素會變成行間特性(原本塊狀特性改變)
新單位
rpx 是小程序提供的一種自適應(yīng)單位,與iphone6的尺寸是1:1,推薦設(shè)計稿以IPHONE6為原型
rpx 與 px 的區(qū)別是什么?

1、px不會自適應(yīng),無論什么機型,什么尺寸屏幕都是一個大小,有些字體不隨設(shè)備屏幕發(fā)生變化時使用px
2、rpx會自適應(yīng),根據(jù)機型發(fā)生相應(yīng)改變
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 => {

});

復(fù)合請求(既有串,也有并)

// 請求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ù)。
所以,假設(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、使用標(biāo)簽(在wxml中)



var msg = "hello world";

module.exports.message = msg;


 {{m1.message}} 
注意事項
1、CSS選擇器其實比官方文檔支持得更多
2、自定義組件的容器如果是行間元素,那么最外層元素會有最小高度21px,所以請盡量使用塊狀元素作為容器
3、wxml不但可以獲取對象的屬性,還可以獲取具體數(shù)組元素
{{arr[0]}}
{{obj.pro}}

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/108325.html

相關(guān)文章

  • Js - 收藏集 - 掘金

    摘要:微信小程序之獲取并解密用戶數(shù)據(jù)獲取后端掘金版權(quán)聲明本文為博主原創(chuàng)文章,若需轉(zhuǎn)載,請注明出處。正題開始,前端怎么學(xué)中文指南基本操作指南前端掘金作者緝熙簡介是推出的一個天挑戰(zhàn)。 使用 JS 在客戶端判斷當(dāng)前網(wǎng)絡(luò)狀態(tài) - 前端 - 掘金 navigator.onLine 通過navigator.onLine判斷當(dāng)前網(wǎng)絡(luò)狀態(tài): if(navigator.onLine){ ...}else{ ....

    gself 評論0 收藏0
  • iKcamp出品|信小程序|小試牛刀(視頻)+發(fā)布流程|基于最版1.0開發(fā)者工具初中級教程分享

    摘要:官網(wǎng)訪問官網(wǎng)更快閱讀全部免費分享課程出品全網(wǎng)最新微信小程序基于最新版開發(fā)者工具之初中級培訓(xùn)教程分享。 iKcamp官網(wǎng):http://www.ikcamp.com 訪問官網(wǎng)更快閱讀全部免費分享課程:《iKcamp出品|全網(wǎng)最新|微信小程序|基于最新版1.0開發(fā)者工具之初中級培訓(xùn)教程分享》。包含:文章、視頻、源代碼 showImg(https://segmentfault.com/i...

    Muninn 評論0 收藏0
  • iKcamp出品|信小程序|小試牛刀(視頻)+發(fā)布流程|基于最版1.0開發(fā)者工具初中級教程分享

    摘要:官網(wǎng)訪問官網(wǎng)更快閱讀全部免費分享課程出品全網(wǎng)最新微信小程序基于最新版開發(fā)者工具之初中級培訓(xùn)教程分享。 iKcamp官網(wǎng):http://www.ikcamp.com 訪問官網(wǎng)更快閱讀全部免費分享課程:《iKcamp出品|全網(wǎng)最新|微信小程序|基于最新版1.0開發(fā)者工具之初中級培訓(xùn)教程分享》。包含:文章、視頻、源代碼 showImg(https://segmentfault.com/i...

    AlphaGooo 評論0 收藏0
  • iKcamp出品|信小程序|小試牛刀(視頻)+發(fā)布流程|基于最版1.0開發(fā)者工具初中級教程分享

    摘要:官網(wǎng)訪問官網(wǎng)更快閱讀全部免費分享課程出品全網(wǎng)最新微信小程序基于最新版開發(fā)者工具之初中級培訓(xùn)教程分享。 iKcamp官網(wǎng):http://www.ikcamp.com 訪問官網(wǎng)更快閱讀全部免費分享課程:《iKcamp出品|全網(wǎng)最新|微信小程序|基于最新版1.0開發(fā)者工具之初中級培訓(xùn)教程分享》。包含:文章、視頻、源代碼 showImg(https://segmentfault.com/i...

    2450184176 評論0 收藏0
  • 信小程序開發(fā)必備神器-Grace

    摘要:一個精巧易用的微信小程序開發(fā)輔助庫特點輕量小巧上手簡單支持和一樣優(yōu)雅的數(shù)據(jù)響應(yīng)式支持?jǐn)?shù)據(jù)自動更新更改緩存批量更新強大的網(wǎng)絡(luò)功能支持全局事件總線支持跨頁面?zhèn)髦抵С质纠こ淘谠创a目錄下用微信小程序開發(fā)工具打開即可。 Grace 一個精巧、易用的微信小程序開發(fā)輔助庫 Github: https://github.com/wendux/grace 特點 輕量、小巧、上手簡單 支持和Vue一樣...

    aikin 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<