精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

從微信小程序到鴻蒙JS開發【02】-數據綁定&tabBar&swiper

開發
文章由鴻蒙社區產出,想要了解更多內容請前往:51CTO和華為官方戰略合作共建的鴻蒙技術社區https://harmonyos.51cto.com/#zz

[[380592]]

想了解更多內容,請訪問:

51CTO和華為官方合作共建的鴻蒙技術社區

https://harmonyos.51cto.com/#zz

1、鴻蒙的數據綁定

微信小程序的數據綁定是類似于Vue的,wxml文件用 {{ }} 和對應js文件中的data對象中的屬性進行綁定。

  1. <view class="city"
  2.     {{ now.location.name }}市 
  3. </view

  1. data: { 
  2.     now: { 
  3.       location: { 
  4.         name"南京" 
  5.       }, 
  6.   } 

  

那么鴻蒙中是否也是這樣綁定呢?嘗試在hml文件的div標簽中使用 {{ }} 綁定js文件中的屬性值,但卻什么都沒有顯示。

  1. <!--錯誤代碼--> 
  2. <div class="container"
  3.     <div class="top"
  4.         <div class="topItem"
  5.             {{t1}} 
  6.         </div> 
  7.         <div class="topItem"
  8.             {{t2}} 
  9.         </div> 
  10.         <div class="topItem"
  11.             {{t3}} 
  12.         </div> 
  13.     </div> 
  14. ... 
  15. </div> 
  1. export default { 
  2.     data: { 
  3.         t1: "吃飯"
  4.         t2: "睡覺"
  5.         t3: "打豆豆" 
  6.     } 

 

其實是因為div標簽中直接放文字是不會顯示的,需要將文字放在標簽中才會顯示出來。將hml文件做些更改,可以看到數據已被綁定到頁面中了。

  1. <div class="container"
  2.     <div class="top"
  3.         <div class="topItem"
  4.             <text> 
  5.                 {{t1}} 
  6.             </text> 
  7.         </div> 
  8.         <div class="topItem"
  9.             <text> 
  10.                 {{t2}} 
  11.             </text> 
  12.         </div> 
  13.         <div class="topItem"
  14.             <text> 
  15.                 {{t3}} 
  16.             </text> 
  17.         </div> 
  18.     </div> 
  19. ... 
  20. </div> 

在一個數組中循環取值的方式和微信小程序也是類似的,可用一個標簽作為邏輯控制塊,其屬性有for和if。需注意循環的每一項索引為$idx,值為$item。需要使用'$'去引用,且沒有類似于wx:for-item等屬性去改變變量名。若要重命名,可寫為for="{{ (index, value) in ... }}

  1. <div class="content"
  2.     <div class="contentItem"
  3.         <block for="{{array}}"
  4.             <div class="item"
  5.                 <text>{{$idx}}: {{$item}}</text> 
  6.             </div> 
  7.         </block> 
  8.     </div> 
  9. </div> 
  1. export default { 
  2.     data: { 
  3.         t1: "吃飯"
  4.         t2: "睡覺"
  5.         t3: "打豆豆"
  6.         array: [1, 3, 5, 7, 9, 2, 4, 6, 8] 
  7.     } 

2、自定義tabBar

在微信小程序中可以直接在app.json中定義一個tabBar。

  1. "tabBar": { 
  2.     "color""#333333"
  3.     "backgroundColor""#fdfdfd"
  4.     "selectedColor""#E20A0B"
  5.     "list": [ 
  6.       { 
  7.         "pagePath""pages/weather/weather"
  8.         "text""天氣"
  9.         "iconPath""icon/weather.png"
  10.         "selectedIconPath""icon/weather1.png" 
  11.       }, 
  12.     ... 
  13.     ] 

 

鴻蒙沒有這種在json中繼承的配置項,但我們可以用flex布局自己寫一個,甚至可以加上動畫等更豐富的功能。考慮到每一個菜單項有選中和未選中兩種狀態,各需準備兩張圖片。將圖片放在/entry/src/main/js/default/common文件夾中,并在js文件中定義菜單欄數據。此處需要注意雖然在目錄結構上common文件夾和頁面js文件存在父級目錄的關系,但在js加載時common被認定為同一級目錄,圖片目錄定義處需注意。

  1. export default { 
  2.     data: { 
  3.         tabBar: [ 
  4.             { 
  5.                 text: "天氣"
  6.                 img1: "./common/icon/weather.png"
  7.                 img2: "./common/icon/weather1.png" 
  8.             }, 
  9.             { 
  10.                 text: "每日新聞"
  11.                 img1: "./common/icon/news.png"
  12.                 img2: "./common/icon/news1.png" 
  13.             }, 
  14.             { 
  15.                 text: "本地新聞"
  16.                 img1: "./common/icon/local.png"
  17.                 img2: "./common/icon/local1.png" 
  18.             }, 
  19.             { 
  20.                 text: "查詢"
  21.                 img1: "./common/icon/search2.png"
  22.                 img2: "./common/icon/search1.png" 
  23.             } 
  24.         ], 
  25.         barIdx: 0, 
  26.     } 

 

頁面設計上,采用position: fixed;將菜單欄固定在頁面底部,并結合flex布局使頁面美觀。判斷當前選中哪一項,則可以使用三元表達式。

  1. <!-- 底部菜單欄 --> 
  2.     <div class="tabBar"
  3.         <block for="{{ tabBar }}"
  4.             <div class="cell" onclick="changeMenu($idx)"
  5.                 <div class="image"
  6.                     <image src="{{ barIdx == $idx ? $item.img2: $item.img1 }}"></image> 
  7.                 </div> 
  8.                 <div class="text"
  9.                     <text class="{{ barIdx == $idx ? 'a' : 'b' }}"
  10.                         {{ $item.text }} 
  11.                     </text> 
  12.                 </div> 
  13.             </div> 
  14.         </block> 
  15.     </div> 

  1. /*底部菜單*/ 
  2. .tabBar { 
  3.     width: 100%; 
  4.     height: 170px; 
  5.     position: fixed; 
  6.     bottom: 0px; 
  7.     border-top: 1px solid #444444; 
  8.     display: flex; 
  9.     justify-content: space-around; 
  10.     align-items: center; 
  11.     background-color: #f5f5f5; 
  12. .cell { 
  13.     width: 20%; 
  14.     height: 160px; 
  15.     display: flex; 
  16.     flex-direction: column
  17. .image { 
  18.     width: 100%; 
  19.     height: 110px; 
  20.     display: flex; 
  21.     justify-content: center; 
  22.     align-items: center; 
  23. .image>image { 
  24.     width: 90px; 
  25.     height: 90px; 
  26. .a { 
  27.     color: #0074DD; 
  28. .b { 
  29.     color: #333333; 
  30. .text { 
  31.     width: 100%; 
  32.     height: 50px; 
  33.     display: flex; 
  34.     justify-content: center; 
  35.     align-items: center; 
  36. .text>text { 
  37.     font-size: 35px; 

div的點擊事件處理屬性為onclick,其不會像微信小程序一樣自動傳入一個事件對象,而需要我們自行定義傳入的參數。如上的onclick="changeMenu($idx)"就是鴻蒙傳入點擊事件的方法。這個函數只需要改變barIdx的值便可以實現點擊切換tabBar對應項的顏色和圖片,達到“四兩撥千斤”的效果。

  1. changeMenu(idx) { 
  2.         this.barIdx = idx; 

 這里又出現了和微信小程序的不同處,微信小程序改變data中的值需要使用wx.setData()函數進行設置,而鴻蒙中直接使用this.key = value即可。

點一下其他菜單項:

 

3、結合swiper進行翻頁

tabBar完成了,但這個菜單欄是寫在一個頁面中的,要怎樣進行翻頁呢?有一個在一個js頁面中實現“翻頁”的方式,就是結合swiper。和微信小程序中的swiper組件一樣,它是一個可滑動的組件,多用于輪播圖、滾動通知等。

鴻蒙的swiper需要定義一個頁面唯一的id屬性,用于點擊事件聯動頁面滑動。index屬性為當前的索引值。

  1. <!-- 劃頁swiper --> 
  2.     <swiper id="pager" index="0" class="pager" onchange="changePage" indicator="false"
  3.     <!--4個div作為4頁--> 
  4.     </swiper> 

  1. /*劃頁swiper*/ 
  2. .pager { 
  3.     width: 100%; 
  4.     height: 100%; 
  5. .pager>div { 
  6.     display: flex; 
  7.     flex-direction: column

 現需要實現兩個功能,滑動swiper實現tabBar聯動樣式變化,以及點擊tabBar中的項聯動swiper頁面滑動。更改changeMenu方法:

  1. changeMenu(idx) { 
  2.     this.barIdx = idx; 
  3.     this.$element("pager").swipeTo({ 
  4.         index: idx 
  5.     }); 

 鴻蒙通過this.$element(id)找到頁面中對應id的組件,如為swiper組件則可使用swipeTo()方法實現滑動,其index屬性則為滑動到的頁面索引值(0開始)。

changePage方法,只需要改變barIdx的值即可。通過swiper的onchange屬性綁定方法名,滑動到的index的值會作為event.index被傳入。

  1. changePage(event) { 
  2.     this.barIdx = event.index

 大功告成。

©著作權歸作者和HarmonyOS技術社區共同所有,如需轉載,請注明出處,否則將追究法律責任。

想了解更多內容,請訪問:

51CTO和華為官方合作共建的鴻蒙技術社區

https://harmonyos.51cto.com/#zz

 

責任編輯:jianghua 來源: 鴻蒙社區
相關推薦

2021-02-21 11:09:18

鴻蒙HarmonyOS應用開發

2021-02-23 12:25:26

鴻蒙HarmonyOS應用開發

2021-03-02 09:29:29

鴻蒙HarmonyOS應用開發

2021-02-20 09:52:02

鴻蒙HarmonyOS應用開發

2021-02-23 12:23:57

鴻蒙HarmonyOS應用開發

2021-02-22 14:56:55

鴻蒙HarmonyOS應用開發

2021-02-25 10:01:19

鴻蒙HarmonyOS應用開發

2021-02-04 13:49:41

鴻蒙HarmonyOS應用開發

2021-02-23 09:52:42

鴻蒙HarmonyOS應用開發

2021-02-07 09:17:24

鴻蒙HarmonyOS應用開發

2021-02-25 15:13:08

鴻蒙HarmonyOS應用開發

2021-02-24 09:36:03

鴻蒙CSS應用開發

2016-11-04 10:48:37

信小程序

2017-05-08 15:03:07

微信小程序開發實戰

2016-09-28 18:10:59

微信程序MINA

2016-11-04 10:49:48

微信小程序

2016-09-27 16:38:24

JavaScript微信Web

2016-09-27 20:36:23

微信HttpWeb

2016-11-04 10:30:17

微信小程序

2018-09-11 10:32:07

云開發小程序開發者
點贊
收藏

51CTO技術棧公眾號

国产精品第三页| 日韩限制级电影在线观看| 欧美日韩大片一区二区三区| 中文字幕免费在线看| 99国内精品久久久久久久| 欧美不卡视频一区| 免费观看成人在线视频| 顶级网黄在线播放| 波多野结衣在线一区| 国产成人精品综合久久久| 亚洲色图综合区| 免费精品国产的网站免费观看| 欧美日韩另类一区| 国内精品视频一区二区三区| 色综合久久久久综合一本到桃花网| 国产成人精品综合在线观看| 国产成人自拍视频在线观看| 久久久全国免费视频| 欧美一区电影| 国产丝袜一区视频在线观看| 91视频福利网| 日日夜夜亚洲| 在线看日韩精品电影| 国产九色porny| 免费黄网在线观看| 久久久久亚洲综合| 国产精品免费在线| 国产精品视频在线观看免费| 免费亚洲视频| 韩国福利视频一区| 日本黄色片免费观看| 国产真实有声精品录音| 亚洲精品久久久久中文字幕欢迎你| 男人午夜视频在线观看| 97成人超碰| 91九色最新地址| 男人靠女人免费视频网站| xvideos国产在线视频| 国产精品网友自拍| 色一情一区二区三区四区| 亚洲人视频在线观看| 国产91丝袜在线18| 91在线短视频| www.蜜臀av.com| 精品影院一区二区久久久| 国产精品视频男人的天堂| 一级一片免费看| 久久精品国语| 国产成人av在线| 在线永久看片免费的视频| 亚洲一区一卡| 国产成人精品在线播放| 懂色av中文字幕| 日本亚洲视频在线| 国产精品自产拍在线观看| 国产一级精品毛片| 麻豆视频观看网址久久| 国产日韩欧美在线| 97成人在线观看| 国产在线精品视频| 亚洲一区中文字幕| www.五月激情| 不卡在线观看av| 精品999在线观看| 日韩电影免费| 国产欧美日韩一区二区三区在线观看| 色综合久久av| 黄色免费在线看| 亚洲精品成人悠悠色影视| 日韩精品一区二区三区四| xxx性欧美| 色狠狠色狠狠综合| 狠狠操狠狠干视频| 超碰成人在线免费| 日韩电影网在线| 国产精品免费无码| 国产高清欧美| 久久久欧美一区二区| 久久久久在线视频| 麻豆成人久久精品二区三区小说| 成人网在线视频| 高h调教冰块play男男双性文| 99国产欧美久久久精品| 日本一区高清在线视频| 欧美被日视频| 亚洲成人av电影| 日本老熟妇毛茸茸| 国产成年精品| 日韩第一页在线| www.99re6| 亚洲深夜av| 91精品国产综合久久香蕉| 国产喷水福利在线视频| 不卡av在线网| 一本—道久久a久久精品蜜桃| 国精产品一区一区三区mba下载| 色婷婷香蕉在线一区二区| 中文字幕一区二区在线观看视频| 国产欧美三级电影| 最近2019年中文视频免费在线观看| 永久看片925tv| 久久久噜噜噜| 成人自拍网站| 日本在线观看网站| 欧美日韩亚洲激情| 亚洲在线观看网站| 精品久久一区| 97久久精品在线| 国产日韩精品suv| 久久久www成人免费无遮挡大片| 亚洲精品少妇一区二区| 456成人影院在线观看| 精品99久久久久久| 中国一级片在线观看| 亚洲免费综合| 国产98在线|日韩| 老司机午夜在线| 在线精品视频一区二区三四| 中文字幕天堂av| 中国成人一区| 国产在线a不卡| 国产69久久| 精品国产福利视频| 亚洲成年人av| 欧美+亚洲+精品+三区| 国产精品日本精品| 国产一级片在线播放| 五月婷婷综合网| 国产人妻精品午夜福利免费| 99久久亚洲精品| 国产精品丝袜久久久久久不卡| 三级av在线播放| 婷婷丁香久久五月婷婷| 性猛交╳xxx乱大交| 欧美.日韩.国产.一区.二区| 91精品在线一区| 欧美尤物美女在线| 欧美日韩高清一区二区三区| 亚洲综合第一区| 欧美a级一区二区| 欧美主播一区二区三区美女 久久精品人| av电影院在线看| 亚洲成av人乱码色午夜| 国产成人无码aa精品一区| 国内精品自线一区二区三区视频| 亚洲黄色一区二区三区| 日本黄色一区| 中文字幕亚洲国产| 亚洲一区中文字幕永久在线| 中文字幕乱码久久午夜不卡| 欧美男女交配视频| 欧美aaaa视频| 91色在线视频| 污视频网站免费在线观看| 日韩欧美国产系列| 久久av高潮av无码av喷吹| 不卡欧美aaaaa| 国产美女无遮挡网站| 国产成人手机高清在线观看网站| 日本久久精品视频| 国产视频网站在线| 欧美三级在线视频| 国产天堂av在线| 成人一区二区视频| 北条麻妃在线视频观看| 国产欧美亚洲精品a| 91精品国产综合久久香蕉的用户体验| 麻豆传媒视频在线观看| 欧美一区二区国产| 日本五十熟hd丰满| 国产亚洲综合色| 免费成人黄色大片| 欧美日韩一卡| 欧洲一区二区日韩在线视频观看免费 | 另类的小说在线视频另类成人小视频在线| 图片区小说区区亚洲五月| 91九色成人| 8x拔播拔播x8国产精品| 北岛玲一区二区三区| 日韩精品一区二区在线观看| 欧美a∨亚洲欧美亚洲| 国产欧美一区二区三区沐欲| 欧美性受xxxx黒人xyx性爽| 在线成人黄色| 亚洲免费视频一区| av日韩精品| 国产精品国模在线| 91cn在线观看| 亚洲三级 欧美三级| 99免费在线视频| 色综合视频一区二区三区高清| 污软件在线观看| 2020国产成人综合网| 国产乱码一区二区三区四区| 国产精品丝袜xxxxxxx| 色乱码一区二区三区熟女| 女仆av观看一区| 91情侣偷在线精品国产| 卡通欧美亚洲| 欧美激情一区二区三区成人| 国产大学生校花援交在线播放 | 中文字幕欧美视频| 国产在线观看黄| 国产精品一区二区婷婷| 韩国精品主播一区二区在线观看| 天天久久夜夜| 狠狠躁18三区二区一区| 国产精品一二三区在线观看| 国产91高潮流白浆在线麻豆| 日韩肉感妇bbwbbwbbw| 99热精品在线| 婷婷视频在线播放| 国产精品美女久久久久久不卡| 91久久综合亚洲鲁鲁五月天| 在线观看精品| 欧美综合激情网| av片在线观看网站| 国产亚洲精品91在线| 视频污在线观看| 欧美狂野另类xxxxoooo| 无码人妻精品一区二区三区蜜桃91 | 日韩在线免费观看av| 国产成人日日夜夜| 思思久久精品视频| 日韩中文字幕麻豆| 91好吊色国产欧美日韩在线| 欧美视频福利| 国产高清不卡无码视频| 亚洲91久久| 亚洲一区二区三区免费看| 久操精品在线| 鲁鲁狠狠狠7777一区二区| 成人看片爽爽爽| 成人欧美视频在线| 亚洲高清999| 亚洲永久免费观看| 国产一区二区三区| 91视频免费网站| 97精品资源在线观看| 国产欧美中文字幕| 丁香久久综合| 国产欧美精品一区二区| 国产精品.xx视频.xxtv| 国产精品美女网站| 粉嫩91精品久久久久久久99蜜桃| 青青久久aⅴ北条麻妃| 免费电影日韩网站| 国产精品扒开腿做爽爽爽男男| 自拍一区在线观看| 国产成人在线播放| 五月激情久久| 国产精品普通话| 亚洲精品69| 91在线播放视频| 久久a爱视频| 欧美大陆一区二区| 国产一区二区在线| 亚洲精品二区| 欧美一区高清| 日韩日韩日韩日韩日韩| 国产欧美一区二区色老头 | 热色播在线视频| 国产99久久精品一区二区永久免费| 桃花岛tv亚洲品质| 国产欧美va欧美va香蕉在| 国产精品国产亚洲精品| yellow视频在线观看一区二区| 国产精品qvod| 欧美日韩免费高清| 成人写真视频| 成人在线视频一区二区三区| av成人国产| 欧美女同在线观看| 国产成人在线影院| 日韩一级视频在线观看| 国产精品美女久久久久久久网站| 久久久久久久久久久久久女过产乱| 亚洲国产人成综合网站| 欧美亚洲另类小说| 91精品啪在线观看国产60岁| 黄频网站在线观看| 在线电影欧美日韩一区二区私密| 黄色网页在线看| 欧美亚洲国产精品| 久久精品xxxxx| 国产精品免费视频一区二区| 欧美日韩中字| 青草视频在线观看视频| 日本特黄久久久高潮| 中文字幕永久免费| 国产欧美一区二区精品仙草咪| 久久久91视频| 91成人网在线| 国精产品一品二品国精品69xx| 亚洲欧美日韩一区二区在线| 国产写真视频在线观看| 欧洲精品在线视频| 精品麻豆剧传媒av国产九九九| 免费日韩av电影| 欧美视频不卡| 欧美激情xxxxx| 欧美 日韩 国产 在线观看| 欧美黑人精品一区二区不卡| av成人亚洲| 国产日韩欧美电影| 国产99视频在线观看| 中文人妻一区二区三区| 精品捆绑调教一区二区三区| 国产乱码精品一区二区三区忘忧草| 日韩在线观看高清| 国产一二三四五| 无码一区二区三区| 亚洲午夜久久久久久久久电影院 | 疯狂做受xxxx欧美肥白少妇| 国产三级精品在线观看| 一区二区三区四区视频| sm久久捆绑调教精品一区| 亚洲精品日韩激情在线电影| 国产在视频线精品视频www666| 国产午夜福利100集发布| 国产一区二区看久久| 国产不卡在线观看视频| 色综合亚洲欧洲| 婷婷开心激情网| 欧美国产日韩免费| 日韩一区二区三区高清在线观看| 亚洲欧洲日韩精品| 日产欧产美韩系列久久99| 一级性生活毛片| 日韩欧美高清在线视频| 天天色棕合合合合合合合| 欧美大片免费看| 日韩亚洲精品在线观看| 青青草影院在线观看| 久久99精品国产麻豆不卡| 欧美亚洲色综久久精品国产| 色偷偷久久一区二区三区| 日本成人一区二区三区| 欧美一性一乱一交一视频| 青青草原在线亚洲| 免费成人午夜视频| 26uuu国产日韩综合| 国产精品黄色大片| 日韩国产高清视频在线| 极品av在线| 欧美一区1区三区3区公司| 另类国产ts人妖高潮视频| 亚洲av无码成人精品国产 | 在线亚洲欧美日韩| 在线精品国产成人综合| 亚洲a∨精品一区二区三区导航| 欧美一级爱爱| 日本免费在线视频不卡一不卡二| 微拍福利一区二区| 欧美日韩国产三级| 国产写真视频在线观看| 99精品在线直播| 激情综合中文娱乐网| 亚洲欧美日本一区| 欧美性jizz18性欧美| 爱久久·www| 亚洲一区二区三区四区在线播放| 女人香蕉久久**毛片精品| 亚洲无人区码一码二码三码| 精品国产成人在线| 黄色大片在线看| 成人激情视频小说免费下载| 重囗味另类老妇506070| 少妇精品无码一区二区三区| 色先锋aa成人| 暖暖日本在线观看| 成人做爰66片免费看网站| 99在线热播精品免费99热| 精品无码一区二区三区| 欧美丰满美乳xxx高潮www| 四虎影院观看视频在线观看| 九九九久久久| 久久99国产精品麻豆| 久久久无码一区二区三区| 亚洲视频在线观看免费| 99精品视频在线免费播放| 欧美二区在线视频| 国产精品久久久久一区二区三区共| 亚洲av无码片一区二区三区 | 亚洲欧美一区二区三区在线观看| 日韩中文字幕在线视频| 成人18夜夜网深夜福利网| 国产一级片黄色| 亚洲精品v日韩精品| 四虎影视2018在线播放alocalhost| 国产精品久久久久av免费| 欧美freesex交免费视频| 国产成人无码一区二区在线观看| 欧美日韩视频一区二区| 啊啊啊久久久| 蜜桃视频成人在线观看| 国产三级三级三级精品8ⅰ区| 亚洲天堂777| 视频区 图片区 小说区| 99国内精品久久久久久久|