当前位置: 首页>开发笔记>正文

小程序頁面設計圖,微信小程序的視圖層總結

小程序頁面設計圖,微信小程序的視圖層總結

一、微信小程序的WXML語法

  1. 數據綁定
    data 中的變量用大括號進行包裹起來,{{}},類似插值表達式,如 {{ message}}
  2. 列表渲染
    列表渲染通過wx:for指令可以對data數據進行渲染,渲染時加上wx:key,進行唯一標識,通過wx:for-item可以指定數組當前元素的變量名,通過wx:for-index可以指定數組當前下標的變量名,代碼示例如下
 <view wx:for="{{ items }}" wx:key="{{ index }}">{{ item }} --- {{ index }}</view> 
data: {message: "hello view",otherMessage: "other message",items: [1, 2, 3, 4],show: false}
  1. 條件渲染
    條件渲染可以通過wx:if指令,還可以wx:elifwx:else等等去進行條件渲染,代碼示例如下
<view wx:if="{{show}}">{{ message }}</view><view wx:else="{{!show}}">{{otherMessage}}</view>
  1. 模版
    在模板中定義代碼片段,然后在不同的地方調用。在定義模版template的時候,使用name屬性,里面就是代碼的內容。使用模版template的時候,使用is屬性,知道是使用的哪一個模版。如果使用模版的時候,想要傳遞數據,可以通過data,示例代碼如下
<template name="header"><view>Header {{message}}</view>
</template><template is="header" data="{{message}}"></template>

如果 data 中的數據是一個對象,想要獲得對象中的某一個值,那么就使用 ...,結構賦值,示例代碼如下

<template name="header"><view>Header {{name}} {{age}}</view>
</template><template is="header" data="{{...mes}}"></template>
data: {message: "hello view",otherMessage: "other message",items: [1, 2, 3, 4],show: false,mes: {name: "張三",age: 23}},
  1. 點擊事件
    小程序中的點擊事件使用 bindTap,如果需要修改值,使用this.setData(),點擊后數據發生變化,示例代碼如下
<view wx:if="{{show}}">{{ message }}</view><view wx:else="{{!show}}" bindtap="handleTap">{{otherMessage}}</view>
handleTap() {// console.log("tap")this.setData({otherMessage: "new message"})}
  1. 微信小程序點擊事件的一些方法總結:
  • 如果是普通的點擊事件,那么就可以用 bindtap,示例代碼如下:
<view class="content" bindtap="handleAddressClick">{{address}}</view>
  • 如果是radio-group,單選按鈕的一些點擊事件,那么就可以用 bindchange,示例代碼如下:
<radio-group bindchange="handleTypeChange"><label><radio value="buy" checked="true" class="buy">求購</radio><radio value="sell">轉讓</radio></label>
</radio-group>
  • 如果是input輸入框的一些點擊事件,那么就可以用 bindinput,示例代碼如下:
<input placeholder="填寫您的具體需求" class="info-input" bindinput="handleMessageChange"></input>
  1. 微信小程序關于發起請求的一些總結:
  • 如果想進行發起請求,可以使用 wx.request() 這個 API,進行發起請求,代碼示例如下:
const data = Object.assign({}, this.staticData, {address: this.data.address,distinct: app.globalData.distinct
})wx.request({url: 'https://nuanwan.wekeji.cn/student/index.php/trade/add_item', data: data,method: "POST",header: {'content-type': 'application/x-www-form-urlencoded'},success: this.handleSubmitScuuess.bind(this)
})
  1. 微信小程序中關于獲取詳情頁的一些方法總結:
  • 在微信小程序中,如果想要實現點擊后,獲取到頁面的一些詳情信息,可以在onLoad() 事件中去實現,在onLoad() 生命周期函數中,傳入options選項,獲取id,頁面一加載就會執行了,代碼示例如下:
// pages/detail/detail.js
const app = getApp()
const header = require("../../components/header/header.js")
const data = Object.assign({}, header.data, {address: "",type: "",message: "",contact: ""
})Page({// data: {//   // address: "",//   // type: "",//   // message: "",//   // contact: ""// },data: data,// 頁面一加載的時候就會獲取到相應的詳情信息,通過id發起請求,獲取到具體的信息onLoad(options) {// console.log(options)this.getDetailInfo(options.id);},getDetailInfo(id) {wx.request({url: 'https://nuanwan.wekeji.cn/student/index.php/trade/get_item',data: {distinct: app.globalData.distinct,id: id},method: "POST",header: {'content-type': 'application/x-www-form-urlencoded'},success: this.getDetailSucc.bind(this)})},getDetailSucc(res) {const result = res.data.data;this.setData({address: result.address,type: result.type,message: result.message,contact: result.contact})}
})

https://www.zydui.com/af810V28FBAZUB1E.html
>

相关文章:

  • 小程序頁面設計圖
  • 小程序界面模板
  • 微信簽到小程序
  • 小程序view覆蓋上一個view
  • 小程序image組件的屬性
  • 微信小程序如何推廣
  • 小程序邏輯層如何運行的js
  • 微信小程序底層邏輯是寫好的
  • vscode搭建nodejs環境,關于VS code ESP-IDF 提示“loading ‘build.ninja‘: 系統找不到指定的文件” 的解決方案
  • 什么是應用軟件并舉例,16.應用舉例
  • 【面經】美團春招三輪面經分享~涵蓋眾多知識點
  • 2021年面試題目,面試題--新增
  • magic king怎么讀,magick++ 簡介
  • 微信怎么設置定時發送,朋友圈可以定時發送嗎?
  • can not connect to rpc service,RPC service
  • ftpserver安卓版,FTPServer
  • server u使用教程,Server-U
  • rpc服務器,RPC 和 Web Service 有什么區別?
  • rpc服務器,web service和rpc的區別
  • psexec
  • dhclient命令,hpe?3par命令行查看狀況腳本
  • hp存儲默認管理口地址,HP3par 多路徑存儲磁盤使用方法
  • hp3par命令行手冊,3par命令集
  • 存儲器芯片的地址范圍,存儲器芯片類別有哪些?
  • 在pc機中各類存儲器,1.14各類存儲器芯片
  • 存儲芯片漲價最新消息,存儲器芯片
  • Windows/Linux性能監控軟件>csv文件,方便生成圖表
  • sqlserver nvarchar,【SQL開發實戰技巧】系列(四十五):Oracle12C常用新特性?VARCHAR2/NVARCHAR2類型最大長度由40
  • arcgis怎么導入地圖,Arcgis路網導入3dmax批量改成道路面
  • 定義animal父類,定義一個父類Animal eat方法 , 定義兩個子類 Dog 特有方法keepHome , Cat 特有方法 catchMouse ;并
  • 手機連接兩個藍牙方法,打開藍牙的設置
  • iconfont圖標免費嗎,關于阿里矢量圖標彩色icon使用
  • ps制作賽博朋克風格,如何用ps做出賽博朋克的風格?
  • ue4綠幕實時導入場景,如何在UE4中制作賽博朋克LED效果
  • 產品經理有哪些培訓課程,2023年全國NPDP產品經理國際認證火熱招生啦
  • B端產品需要什么能力,NPDP認證|B端產品經理是如何做競品調研的?
  • 超級工具,Supershell 一款牛叉閃閃的工具
  • buffer在c語言中是什么意思,QBuffer 用法理解