一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

node.js|vue.js|jquery|angularjs|React|json|js教程|

服務器之家 - 編程語言 - JavaScript - js教程 - 微信小程序開發篇之踩坑記錄

微信小程序開發篇之踩坑記錄

2022-02-16 17:36孫夢舸 js教程

這篇文章主要給大家介紹了關于微信小程序開發篇之踩坑記錄的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

最近參與開發了公司的第一款小程序,開發體驗基本類似于基于webview的混合式開發,可以調用官方強大的api,但也有一些坑或者說不習慣的地方。這篇文章從實用性出發,記錄了開發過程中的一些問題:

1. 樣式優先級混亂

在使用button組件時,發現在class中設置width不生效,下面貼上代碼:

.my-button{
 width: 140rpx;
 height: 60rpx;
 line-height: 60rpx;
 padding: 0;
}

經過微信調試工具排查后,發現user agent的樣式優先級居然大于我們自己寫的樣式類,這在瀏覽器中基本是不可能發生的事情

微信小程序開發篇之踩坑記錄

解決方案其實比較簡單,給width添加!important的后綴或者style="width:140rpx"即可,修改后我們再看一下效果:

微信小程序開發篇之踩坑記錄

微信小程序開發篇之踩坑記錄

加上!important之后,其實寬度的實際效果已經符合我們的預期了,但是微信調試工具卻仍然顯示user agent樣式優先,這應該算是調試工具的一個bug吧。

2. 普通UI組件封裝,參數定義繁瑣

一般UI視覺稿中的基礎組件,例如button,是有特定樣式的:比方說背景色/字體。利用小程序的Component函數封裝成組件,編寫默認樣式并接收外部傳入的class,可以方便后續開發。

React有<tag {...props}></tag>這種寫法,即組件接收props不做處理,只透傳給下一個組件,但小程序不支持這種寫法(苦搜無果,官方文檔也沒有說明)。

這就意味著我們需要把所有button組件支持的參數都羅列在properties中:

properties: {
  classes: {
   type: String,
   value: "",
  },
  type: {
   type: String,
   value: "default",
  },
  plain: {
   type: Boolean,
   value: false,
  },
  size: {
   type: String,
   value: "default",
  },
  ......
 },

3. 全局樣式選擇器*被禁用

*{
 box-sizing: border-box;
}

上面的代碼在編譯的時候就會報錯,因為小程序禁用了這類選擇器。大膽猜測具體原因:這類作用范圍比較廣的選擇器和自定義組件的樣式隔離產生了沖突??

那怎么去給小程序添加全局通用樣式?看來只能自己把用到的標簽都手動寫一遍了,還好網上有現成的代碼可以貼:

view,scroll-view,swiper,swiper-item,movable-area,movable-view,cover-view,cover-image,icon,text,rich-text,progress,button,checkbox-group,checkbox,form,input,label,picker,picker-view,radio-group,radio,slider,switch,textarea,navigator,functional-page-navigator,image,video,camera,live-player,live-pusher,map,canvas,open-data,web-view,ad{
 box-sizing: border-box;
}

4. 自定義組件,bind:tap調用兩次

封裝基礎組件時,例如button,下面的寫法應當避免:

onTap(e) {
 if (!this.data.disabled && !this.data.loading) {
  this.triggerEvent("tap", e.detail)
 }
},
<button bindtap="onTap"></button>

這樣封裝出來的組件,會觸發兩次tap事件,一次是小程序自身觸發的,一次是通過triggerEvent觸發。

可以換一個非小程序內置的事件類型,比如click:

onTap(e) {
 if (!this.data.disabled && !this.data.loading) {
  this.triggerEvent("click", e.detail)
 }
},

阻止tap事件冒泡也可以解決:

<button catchtap="onTap"></button>

5. 在wxml中用Boolean()做類型轉換

例如在一個組件中,監聽一個String類型的參數,如果不為空則顯示text標簽,否則不顯示:

// player.wxml
<text class="text1" wx:if="{{ Boolean(leftText) }}">{{ leftText }}</text>
// index.wxml
<player leftText="范讀"></player>

這種寫法,leftText字段很明顯已經傳遞了,但是依舊不顯示text標簽,當換一種寫法后:

// player.wxml
<text class="text1" wx:if="{{ leftText }}">{{ leftText }}</text>

這樣就是正確的,符合我們的期望。

神奇吧?

6. InnerAudioContext調用seek方法后,onTimeUpdate回調失效

InnerAudioContext用于播放音頻,給它傳入onTimeUpdate回調從而獲取當前的播放進度。

但是當調用seek方法跳轉到指定位置播放時,onTimeUpdate就不再被調用了。

小程序社區其實很多人已經提過這個問題,大概經歷了1年半的時間可微信團隊遲遲沒有修復,只能暫時使用折中的辦法來修復,解決方案其實很簡單:

progressOnChange(e) {
 if (this.properties.src && this.data.innerAudioContext) {
  const innerAudioContext = this.data.innerAudioContext;
  innerAudioContext.pause();
  innerAudioContext.seek(innerAudioContext.duration * e.detail.value / 100);
  setTimeout(() => {
   innerAudioContext.play();
  }, 500);
 }
},

先暫停播放,再執行seek方法,然后設置大概500ms的延時調用play方法。

7. InnerAudioContext獲取duration的時機問題

本想在音頻播放前拿到duration應該是實現不了了,網上關于調用onPlay、onCanplay的說法都不太靠譜,其中一個方案是這樣的:

innerAudioContext.onCanplay(() => {
 setTimeout(() => {
  this.setData({
   durationStr: secondToTimeStr(innerAudioContext.duration) || "--:--",
  });
 }, 500);
});

且不說setTimeout設置多少毫秒合適,真機上是無效的。

因此還是老老實實的用onTimeUpdate:

innerAudioContext.onTimeUpdate(() => {
 this.setData({
  durationStr: secondToTimeStr(innerAudioContext.duration) || "--:--"
 })
});

如果說覺得每次onTimeUpdate都要計算一次很耗性能的話,可以自行實現只計算一次。

8. 設置頁面背景色

當前頁面的json文件中有個backgroundColor字段,但是設置后無效,后面發現這個字段表示的不是可見區域的背景色,而是頁面下拉時窗口的背景色。

微信小程序開發篇之踩坑記錄

如果需要設置頁面背景色,可以通過page標簽的樣式設置:

page{
 background: #f9fafb;
}

總結

到此這篇關于微信小程序開發篇之踩坑記錄的文章就介紹到這了,更多相關微信小程序開發踩坑內容請搜索服務器之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持服務器之家!

原文鏈接:https://juejin.cn/post/6884089615700426766

延伸 · 閱讀

精彩推薦
  • js教程javascript實現簡單留言板案例

    javascript實現簡單留言板案例

    這篇文章主要為大家詳細介紹了javascript實現簡單留言板案例,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下...

    愛前端的茂茂8052022-01-20
  • js教程JavaScript 繪制餅圖的示例

    JavaScript 繪制餅圖的示例

    這篇文章主要介紹了JavaScript 繪制餅圖的示例,幫助大家更好的利用JavaScript繪制圖表,感興趣的朋友可以了解下...

    MwqgKG11392022-01-21
  • js教程JavaScript實現4位隨機驗證碼的生成

    JavaScript實現4位隨機驗證碼的生成

    這篇文章主要為大家詳細介紹了JavaScript實現4位隨機驗證碼的生成,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下...

    weixin_4202683110452022-01-10
  • js教程js編寫輪播圖效果

    js編寫輪播圖效果

    這篇文章主要為大家詳細介紹了js編寫輪播圖效果的代碼,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下...

    晚咹4802022-02-16
  • js教程JavaScript 實現繼承的幾種方式

    JavaScript 實現繼承的幾種方式

    這篇文章主要介紹了JavaScript 實現繼承的幾種方式,幫助大家更好的理解和使用JavaScript,感興趣的朋友可以了解下...

    him89802022-01-21
  • js教程通過滑動翻頁效果實現和移動端click事件問題

    通過滑動翻頁效果實現和移動端click事件問題

    這篇文章主要介紹了滑動翻頁效果實現和移動端click事件問題,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需...

    行舟客5412022-01-07
  • js教程js實現電燈開關效果

    js實現電燈開關效果

    這篇文章主要為大家詳細介紹了js實現電燈開關效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下...

    小蘇(o﹃o )7162022-01-04
  • js教程微信小程序視頻彈幕發送功能的實現

    微信小程序視頻彈幕發送功能的實現

    這篇文章主要介紹了微信小程序視頻彈幕發送功能的實現,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的...

    保護我方豆豆5052021-12-21
主站蜘蛛池模板: 俺去俺去啦最新官网在线 | 好大好硬好深好爽gif图 | 草逼视频网站 | 日本人成在线视频免费播放 | 香蕉在线播放 | 日本伦理动漫在线观看 | 亚州在线视频 | 特黄特色大片免费视频大全 | 免费成年视频 | futa文| 亚洲精品一区二区观看 | 日本一区二区视频在线观看 | 女八把屁股扒开让男生添 | 茄子视频懂你更多apl | 亚洲zooz人禽交xxxx | 丝瓜视频黄色在线观看 | 青青在线国产视频 | 天干夜天天夜天干天ww | 污丝瓜视频| 精品无人区麻豆乱码1区2 | 欧美午夜寂寞影院安卓列表 | 1024免费福利永久观看网站 | 亚洲天堂导航 | np高h疯狂黄暴宫口 narutomanga玖辛奈之乳 | 精品一区二区三区在线播放 | www射com| 26uuu老色哥 236宅宅2021最新理论 | chinaese中国女人厕所小便 | 国内自拍网红在综合图区 | 国产毛片在线观看 | 好男人资源免费播放 | 日韩精选在线 | chinesemature丰满成熟 | 欧美女孩13一14v | 果冻传媒天美传媒乌鸦传媒 | 精品国产品香蕉在线观看 | 日本漫画工囗全彩番在线 | 日韩毛片在线影视 | 丝袜足控免费网站xx动漫漫画 | 欧洲一级 | 成全动漫视频在线观看 |