1. 程式人生 > >微信小程序WXML模板

微信小程序WXML模板

生效 手寫 當前 hello 由於 組合 行為 記錄 data

WXML 模板

從事過網頁編程的人知道,網頁編程采用的是 HTML + CSS + JS 這樣的組合,其中 HTML 是用來描述當前這個頁面的結構,CSS 用來描述頁面的樣子,JS 通常是用來處理這個頁面和用戶的交互。

同樣道理,在小程序中也有同樣的角色,其中 WXML 充當的就是類似 HTML 的角色。打開 pages/index/index.wxml,你會看到以下的內容:

<view class="container">

<view class="userinfo">

<button wx:if="{{!hasUserInfo && canIUse}}"> 獲取頭像昵稱 </button>

<block wx:else>

<image src="{{userInfo.avatarUrl}}" background-size="cover"></image>

<text class="userinfo-nickname">{{userInfo.nickName}}</text>

</block>

</view>

<view class="usermotto">

<text class="user-motto">{{motto}}</text>

</view>

</view>

HTML 非常相似,有標簽、屬性等等構成。但是也有很多不一樣的地方,我們來一一闡述一下:

標簽名字有點不一樣 往往寫 HTML 的時候,經常會用到的標簽是 div, p, span,開發者在寫一個頁面的時候可以根據這些基礎的標簽組合出不一樣的組件,例如日歷、彈窗等等。換個思路,既然大家都需要這些組件,為什麽我們不能把這些常用的組件包裝起來,大大提高我們的開發效率。 從上邊的例子可以看到,小程序的 WXML 用的標簽是 view, button, text 等等,這些標簽就是小程序給開發者包裝好的基本能力,我們還提供了地圖、視頻、音頻等等組件能力 更多詳細的組件講述參考下個章節 小程序的能力

多了一些 wx:if 這樣的屬性以及 {{ }} 這樣的表達式 在網頁的一般開發流程中,我們通常會通過 JS 操作 DOM (對應 HTML 的描述產生的樹),以引起界面的一些變化響應用戶的行為。例如,用戶點擊某個按鈕的時候,JS 會記錄一些狀態到 JS 變量裏邊,同時通過 DOM API 操控 DOM 的屬性或者行為,進而引起界面一些變化。當項目越來越大的時候,你的代碼會充斥著非常多的界面交互邏輯和程序的各種狀態變量,顯然這不是一個很好的開發模式,因此就有了 MVVM 的開發模式(例如 React, Vue),提倡把渲染和邏輯分離。簡單來說就是不要再讓 JS 直接操控 DOM,JS只需要管理狀態即可,然後再通過一種模板語法來描述狀態和界面結構的關系即可。 小程序的框架也是用到了這個思路,如果你需要把一個 Hello World 的字符串顯示在界面上。 WXML 是這麽寫 :

<text></text>

JS 只需要管理狀態即可:

this.setData({ msg: "Hello World" })

通過 {{ }} 的語法把一個變量綁定到界面上,我們稱為數據綁定。僅僅通過數據綁定還不夠完整的描述狀態和界面的關系,還需要 if/else, for等控制能力,在小程序裏邊,這些控制能力都用 wx: 開頭的屬性來表達。 更詳細的文檔可以參考 WXML

WXSS 樣式

WXSS 具有 CSS 大部分的特性,小程序在 WXSS 也做了一些擴充和修改。

  1. 新增了尺寸單位。在寫 CSS 樣式時,開發者需要考慮到手機設備的屏幕會有不同的寬度和設備像素比,采用一些技巧來換算一些像素單位。WXSS 在底層支持新的尺寸單位 rpx ,開發者可以免去換算的煩惱,只要交給小程序底層來換算即可,由於換算采用的浮點數運算,所以運算結果會和預期結果有一點點偏差。
  2. 提供了全局的樣式和局部樣式。和前邊 app.json, page.json 的概念相同,你可以寫一個 app.wxss 作為全局樣式,會作用於當前小程序的所有頁面,局部頁面樣式 page.wxss 僅對當前頁面生效。
  3. 此外 WXSS 僅支持部分 CSS 選擇器

更詳細的文檔可以參考 WXSS 。

微信小程序開發神器《微信小程序自動切片生成布局軟件》,可以快速自動生成小程序前端布局和代碼,還有免費的教程和技術支持。

功能如下:

1、切片功能:原來手寫的這部分工作,可以用切片軟件的方法來切。切好後,可以自動生成wxml,wcss,js文件。

2、文字識別功能:效果圖上的文字可以通過自動文字識別識別出來,提高錄入的速度,減輕工作量。

3、存檔功能:設計好的切片文件可以存檔,以便下次需要的時候拿來重新編輯。只要有切片文件在,換了程序也可以秀給和編輯。

有任何疑問歡迎隨時聯系我們!

Q Q : 348961183

官方網址:http://www.ymznkf.com/index.aspx?tg=5800

軟件下載地址:http://www.ymznkf.com/new_view_559.htm

微信小程序WXML模板