從品牌網(wǎng)站建設(shè)到網(wǎng)絡(luò)營銷策劃,從策略到執(zhí)行的一站式服務(wù)
來源:中聯(lián)星空網(wǎng)絡(luò)科技有限公司 | 2020.08.27
內(nèi)容主要涉及到小程序相關(guān)的五個方面。
1、Text組件
2、單位(RPX)
3、生命周期
4、template模板
5、播放器插件
逐一來看一下。
一、Text組件
小程序中view組件的使用相當(dāng)于就是一個div標(biāo)簽,而text組件相當(dāng)于就是一個文本標(biāo)簽b/span這樣子,然而,其實(shí)一段文字我們可以使用text組件來包裹,也可以不用text組件而直接使用view組件來包裹,那二者有什么區(qū)別呢?
很明顯,小程序給TEXT組件賦予了特殊能力。而且使用TEXT組件包裹文件更容易控制它的樣式。所以,通過一些個對比和測試,我對text組件的認(rèn)識就是兩點(diǎn):
1、用TEXT組件包裹的內(nèi)容好寫樣式,來控制它的顯示UI。
2、在小程序中只有TEXT包圍的文本才可長按選中,這一點(diǎn)小程序給text組件賦予了一個屬性。
二、單位RPX
談一下我對RPX這個單位的認(rèn)識, 小程序特有的一個單位。首先,小程序開發(fā)可以看成是一個移動web的開發(fā)。 竟然是一個移動端的開發(fā),那么我們就應(yīng)該用移動端的思維去寫代碼,就移動端有一些特殊的特征需要我們?nèi)タ紤],比如:
1、最重要的!,如何在不同的機(jī)型上做適配。
2、模擬器ip6分辨率375和設(shè)計稿750的因?yàn)樗匀魂P(guān)系。
這張圖我已經(jīng)在多個地方講過了,通過這張圖我們可以知道,模擬器ip6的375是一個邏輯分辨率的概念,單位可以認(rèn)為是PT,它和我們?nèi)粘2季种械腃SS像素在數(shù)值大小上是同一個東西,而物理分辨率(如上750*1334)才是設(shè)備真正分辨率的概念,它和前面說的邏輯像素數(shù)值上有一個對應(yīng)的關(guān)系(Reader)。也就是表示一個邏輯像素包含幾個物理像素問題。知道了這些之后,我們就來看一下小程序序里RPX那點(diǎn)事。
我們來看一下RPX的作用,看它解決了一個什么問題。
1、ip6下1px =1rpx=0.5pt
這里說的PX指的是物理分辨率1px。這個就是小程序的規(guī)定,以ip6的物理像素750X1334為視覺稿進(jìn)行設(shè)計,只不過小程序定了個不一樣的單位叫RPX(responsive
pixel)。然而,使用RPX,小程序會自動在不同的分辨率下進(jìn)行轉(zhuǎn)換。從而達(dá)到適配的效果。
小程序開發(fā)需要關(guān)注的幾個知識點(diǎn)
可以理解:小程序中的RPX相當(dāng)于就是移動端開發(fā)中PX/rem/em等單位用來表示視覺上與設(shè)備分辨率上的一個邏輯關(guān)系 。
2、不是所有的單位都適合用rpx。
RPX是會根據(jù)不同機(jī)型去做自適應(yīng)調(diào)整的,而有時候我們不需要去做這么一個調(diào)整。
比如,對于一些個文字介紹,使用RPX后,小屏幕看起來就完全不可控,顯示效果上看著比較小,甚至出現(xiàn)看不清楚的情況,還有一些標(biāo)題的情況,可能我們在任何機(jī)型上想要看到的就是一個加粗定大的效果。這種情況下,其實(shí)我覺得我們還是可以使用PX作為單位來控制比較適合一些。
三、生命周期
小程序也有生命周期,其實(shí)整個開發(fā)流程和前端框架React/vue等都類似,所以,這個我對比著來看一下小程序中的生命同期的概念。
對于那些對外暴露的方法,onLoad/onShow/onReady都好理解。在頁面初始化數(shù)據(jù)的處理方式上有一點(diǎn)需要注意的地方:
1、在React框架
實(shí)際上跑完willmount之后會產(chǎn)生render,然后在執(zhí)行didmount,如果在didmount中如果有數(shù)據(jù)發(fā)生變化,使用setState處理變化后,再去執(zhí)行render。
在willmount中我們可以使用this.state.xxx來初始化變量的值。
2、小程序架構(gòu)
然而,在小程序的生命周期內(nèi),我們是否可以在onLoad中使用this.data.xxx來初始化變量呢?
答案是不行的,可能之前的版本是可以的,查了一下小程序文檔。
四、template
WXML提供模板(template),可以在模板中定義代碼片段,然后在不同的地方調(diào)用。
模板的使用非常簡單,文檔中的說的很清楚,那么關(guān)于這個清楚的描述,我對模板有兩點(diǎn)認(rèn)識:
1、區(qū)別于腳本引入可以使用絕對路徑
腳本的引入是只能使用相對地址的,而模板的引入可以使用絕對路徑。
2、模板化不是模塊化
有沒有發(fā)現(xiàn)在模板文件中其實(shí)少了一個文件,shipin-item-template.js,對,這里是不能加這個腳本文件的,所以從業(yè)務(wù)角度上來說,無法將邏輯單獨(dú)出來。因此,小程序時原模板只是一個模板不是一個模塊。