微信小程序实战 (WXML:小程序版HTML)

简介: 微信小程序实战 (WXML:小程序版HTML)

上一篇讲了小程序框架基础,这一篇介绍WXML:小程序版HTML。

1.标签与属性

常用基础标签text view

特征:

text 类似html span标签 行内元素,不换行;

view 类似html div标签 块级元素,换行;

新建页面

<text>text 类似html span标签 行内元素</text>
<text>,不换行</text>
<view>view 类似html div标签 块级元素</view>
<view>view 类似html div标签 换行</view>
复制代码

测试

网络异常,图片无法展示
|
公共属性

所有组件都有以下属性:

网络异常,图片无法展示
|

2.数据绑定

数据绑定功能使得程序在运行过程中,具备动态改变渲染界面的能力,从而达到了更好的用户体验效果。在
WEB开发中,需要借助JavaScript并通过DOM接口来实现界面的动态更新,而在小程序中,则是使用WXML
语言提供的数据绑定功能来实现的。
复制代码

2.1简单数据绑定

data: {
    id:1, message: 'Hello MINA!', 
    number:1234, 
    condition:true, 
    isChecked:true, 
    person:{ name:"张三", age:25, sex:"男" }
  },
复制代码
<view>{{message}}</view> 
<view>{{number}}</view> 
<view>{{condition}}</view> 
<view>{{isChecked}}</view> 
<view>{{person}}</view> 
<view>{{person.name}}</view> 
<view>{{person.age}}</view> 
<view>{{person.sex}}</view> <!-- 自定义属性 data-* --> 
<view data-number="{{number}}">自定义属性</view> <!-- 组件属性(需要在双引号之内) --> 
<view id="item-{{id}}">组件属性</view> <!-- 控制属性(需要在双引号之内) --> 
<view wx:if="{{condition}}">控制属性</view> <!-- 使用布尔类型充当属性 --> 
<checkbox checked="{{isChecked}}"></checkbox>
复制代码

测试:

网络异常,图片无法展示
|

2.2运算

可以在 {{}} 内进行简单的运算,支持的有如下几种方式

2.2.1 三元运算

如果flag条件是true 则hidden =true 如果flag条件是false 则hidden =false

<view hidden="{{flag?true:false}}">三元运算</view>
复制代码

网络异常,图片无法展示
|

2.2.2 算数运算

<view> {{a + b}} + {{c}} + d </view>
复制代码
a: 1, 
    b: 2, 
    c: 3
复制代码

2.2.3 逻辑判断

当length大于5时展示逻辑判断

<view wx:if="{{length > 5}}">逻辑判断</view>
复制代码

网络异常,图片无法展示
|

2.2.4 字符串运算

<view>{{"hello " + name}}</view>
复制代码

2.2.5 数据路径运算

<view>{{object.key}} {{array[0]}}</view>
复制代码
object: { key: ' 数据路径运算 ' },
    array: ['MINA','safsd']
复制代码

3.列表渲染

在组件上使用 wx:for 控制属性绑定一个数组,即可使用数组中各项的数据重复渲染该组件。(就是说数组有多少条数据,他就会渲染该组件多少次)

userArray:[ 
      { id:1, name:"张三" },
      { id:2, name:"李四" },
      { id:3, name:"王五" } 
    ]
复制代码
<view wx:for="{{userArray}}" wx:for-item="item" wx:for-index="index"> {{index}}-{{item.id}}-{{item.name}} </view>
复制代码

测试

网络异常,图片无法展示
|

4.条件渲染

4.1 wx:if

在框架中,使用 wx:if="" 来判断是否需要渲染该代码块:

<view wx:if="{{condition}}"> True </view>
复制代码

也可以用 wx:elif 和 wx:else 来添加一个 else 块:

<view wx:if="{{length > 5}}"> 1 </view>
<view wx:elif="{{length > 2}}"> 2 </view>
<view wx:else> 3 </view>
复制代码

4.2 block wx:if

因为 wx:if 是一个控制属性,需要将它添加到一个标签上。如果要一次性判断多个组件标签,可以使

用一个  标签将多个组件包装起来(这样避免每个组件都要写一遍 wx:if判断条件),并在上边使用 wx:if 控制属性。

<block wx:if="{{true}}">
<view> view1 </view>
<view> view2 </view>
</block>
复制代码

注意:  并不是一个组件,它仅仅是一个包装元素,不会在页面中做任何渲染,只接受控制属性。

4.2 hidden 与 wx:if

使用

<view hidden="{{condition}}">hidden</view>
复制代码

他们有什么区别呢?

wx:if 也是惰性的,如果在初始渲染条件为 false ,框架什么也不做,在条件第一次变成真的时候才开始局部渲染。
hidden 就简单的多,组件始终会被渲染,只是简单的控制显示与隐藏。
复制代码

他们的使用场景

一般来说, wx:if 有更高的切换消耗而 hidden 有更高的初始渲染消耗。因此,如果需要频繁切换的情景下,用 hidden 更好,如果在运行时条件不大可能改变则 wx:if 较好。
复制代码

5.模板

WXML提供模板(template),可以在模板中定义代码片段,然后在不同的地方调用。

5.1定义模版

使用 name 属性,作为模板的名字。然后在 template 内定义代码片段,如:

<!--
index: int
msg: string
time: string
-->
<template name="msgItem">
<view>
<text> {{index}}: {{msg}} </text>
<text> Time: {{time}} </text>
</view>
</template>
复制代码

5.2使用模版

使用 is 属性,声明需要的使用的模板,然后将模板所需要的 data 传入,如:

<template is="msgItem" data="{{...item}}"/>
复制代码
data: {
    item: { 
      index: 0,
       msg: 'this is a template',
        time: '2022-10-07' 
      }
  },
复制代码

网络异常,图片无法展示
|

5.3模版的作用域

模板拥有自己的作用域,只能使用 data 传入的数据以及模板定义文件中定义的  模块。

6.引用

WXML 提供两种文件引用方式 import 和 include 。

6.1 import

import 可以在该文件中使用目标文件定义的 template ,如:

在 item.wxml 中定义了一个叫 item 的 template :

<!-- item.wxml -->
<template name="item">
  <text>{{text}}</text>
</template>
复制代码

在 importTest.wxml 中引用了 item.wxml,就可以使用 item 模板:

<import src="item.wxml"/> 
<view>模板引入</view>
<template is="item" data="{{text: 'forbar'}}"/>
复制代码

import 的作用域

import 有作用域的概念,即只会 import 目标文件中定义的 template,而不会 import 目标文件import 的 template。(额,比较绕,就是不能引用引用的引用)

如:C import B,B import A,在C中可以使用B定义的 template ,在B中可以使用A定义的 template ,但是C不能使用A定义的 template 。

6.2 include

include 可以将目标文件除了 template、 wxs 外的整个代码引入,相当于是拷贝到 include

位置,如:

<view>测试include </view>
<!-- index.wxml -->
<include src="header.wxml"/>
<view> body </view>
<include src="footer.wxml"/>
复制代码
<!-- header.wxml -->
<view> header </view>
复制代码
<!-- footer.wxml -->
<view> footer </view>
复制代码

网络异常,图片无法展示
|

7.事件

7.1 什么是事件?

官文

事件是视图层到逻辑层的通讯方式。
事件可以将用户的行为反馈到逻辑层进行处理。
事件可以绑定在组件上,当达到触发事件,就会执行逻辑层中对应的事件处理函数。
事件对象可以携带额外信息,如 id, dataset, touches。
复制代码

7.2 事件使用方式

<!--pages/eventTest/eventTest.wxml-->
<text>pages/eventTest/eventTest.wxml</text>
<view id="tapTest" data-hi="Weixin"  bindtap="tapName"> 点击事件测试 </view>
复制代码
/**
   * 点击事件处理逻辑
   * @param {*} event 
   */
  tapName: function(event) {
     console.log(event) 
    },
复制代码

网络异常,图片无法展示
|

7.3 事件分类

根据组件触发事件时是否会向父节点传递,将事件分为冒泡事件、非冒泡事件

7.4 绑定并阻止事件冒泡

属性catch 会阻止事件向上冒泡

<view id="outer" bindtap="handleTap1">
  outer view
  <view id="middle" catchtap="handleTap2">
    middle view
    <view id="inner" bindtap="handleTap3">
      inner view
    </view>
  </view>
</view>
复制代码
handleTap1: function(event) {
    console.log("handleTap1:"+event) 
    },
    handleTap2: function(event) {
    console.log("handleTap2:"+event) 
    },
    handleTap3: function(event) {
    console.log("handleTap3:"+event) 
    },
复制代码

测试,点击 inner view 发现控制台打印handleTap3 、handleTap2 说明事件在handleTap2时已经阻止了冒泡传递,因此阻止事件冒泡可以使用catch属性

网络异常,图片无法展示
|

实例1 (实现文本输入框和文本框数据同步)

<input type="text" style="border:1px solid;padding:2px;margin:2px;" bindinput="handleInput" /> <text>文本框的值是:{{num}}</text>
复制代码
handleInput: function(e) {
    console.log(e.detail.value); 
    this.setData({ num:e.detail.value })    
  },
复制代码

测试输入框内容发生改变时,触发handleInput 事件逻辑,执行num赋值操作。

网络异常,图片无法展示
|

实例2 (实现简单加计算器)

<view>-实现简单加计算器-</view>
<input type="number" model:value="{{numA}}" class="inputNumber"/> 
<button>+</button> 
<input type="number" model:value="{{numB}}" class="inputNumber"/> 
<button bindtap="handleTap">=</button> 
<input type="number" disabled value="{{total}}" class="inputNumber"/>
复制代码

样式文件

/* pages/eventTest/eventTest.wxss */
.inputNumber{ 
  border:1px solid gray; 
  padding:2px; 
  margin:1px 20px 1px 20px; 
}
复制代码
data: {
    numA:'', 
    numB:'', 
    total:''
  },
  /** 处理按钮点击事件 
   * @param {} e 事件源 
   **/ 
  handleTap(e){ 
    console.log(e); 
    console.log(this.data.numA); 
    console.log(this.data.numB); 
    this.setData({ total:parseInt(this.data.numA)+parseInt(this.data.numB) }) 
  },
复制代码

进阶,事件传参功能 使用data-*

data-*
自定义属性
组件上触发的事件时,会发送给事件处理
复制代码

按钮修改为data-action="=" ,设置action 参数为 =

<button bindtap="handleTap" data-action="=">=</button> 
复制代码

在handleTap 逻辑中获取自定义action参数 ,进行判断

/** 处理按钮点击事件 
   * @param {} e 事件源 
   **/ 
  handleTap(e){ 
    let action=e.currentTarget.dataset.action;
    console.log("获取自定义参数action :"+action);
    console.log(e); 
    console.log(this.data.numA); 
    console.log(this.data.numB); 
    if(action =="="){
      this.setData({ total:parseInt(this.data.numA)+parseInt(this.data.numB) }) 
    }else{
      console.log("获取自定义参数action获取失败")
    }
  },
复制代码

至此WXML:小程序版HTML结束

下一篇: WXSS:小程序版CSS


相关文章
|
2月前
|
存储 JSON 小程序
微信小程序入门之新建并认识小程序结构
微信小程序入门之新建并认识小程序结构
53 1
ly~
|
3月前
|
存储 供应链 小程序
除了微信小程序,PHP 还可以用于开发哪些类型的小程序?
除了微信小程序,PHP 还可用于开发多种类型的小程序,包括支付宝小程序、百度智能小程序、抖音小程序、企业内部小程序及行业特定小程序。在电商、生活服务、资讯、工具、娱乐、营销等领域,PHP 能有效管理商品信息、订单处理、支付接口、内容抓取、复杂计算、游戏数据、活动规则等多种业务。同时,在企业内部,PHP 可提升工作效率,实现审批流程、文件共享、生产计划等功能;在医疗和教育等行业,PHP 能管理患者信息、在线问诊、课程资源、成绩查询等重要数据。
ly~
83 6
|
1月前
|
JavaScript API 开发工具
<大厂实战场景> ~ Flutter&鸿蒙next 解析后端返回的 HTML 数据详解
本文介绍了如何在 Flutter 中解析后端返回的 HTML 数据。首先解释了 HTML 解析的概念,然后详细介绍了使用 `http` 和 `html` 库的步骤,包括添加依赖、获取 HTML 数据、解析 HTML 内容和在 Flutter UI 中显示解析结果。通过具体的代码示例,展示了如何从 URL 获取 HTML 并提取特定信息,如链接列表。希望本文能帮助你在 Flutter 应用中更好地处理 HTML 数据。
109 1
|
2月前
|
小程序 JavaScript API
微信小程序开发之:保存图片到手机,使用uni-app 开发小程序;还有微信原生保存图片到手机
这篇文章介绍了如何在uni-app和微信小程序中实现将图片保存到用户手机相册的功能。
769 0
微信小程序开发之:保存图片到手机,使用uni-app 开发小程序;还有微信原生保存图片到手机
|
2月前
|
JavaScript 小程序 开发者
uni-app开发实战:利用Vue混入(mixin)实现微信小程序全局分享功能,一键发送给朋友、分享到朋友圈、复制链接
uni-app开发实战:利用Vue混入(mixin)实现微信小程序全局分享功能,一键发送给朋友、分享到朋友圈、复制链接
405 0
|
3月前
|
搜索推荐
2024微信个人名片在线生成HTML源码
微信个人名片卡片在线生成,这是一款微信个人名片生成网站源码,无第三方接口,本地直接生成可长期使用。 主要用于生成用户个性化的名片页面,包括头像、姓名、联系方式、个人介绍等信息。 在本地浏览器打开即可,源码是html的,也可上传到服务器上。
54 0
2024微信个人名片在线生成HTML源码
|
4月前
|
存储 缓存 移动开发
不来看一看HTML请求后端性能优化的实战总结吗?
本文主要总结了在ICBU的核心沟通场景下服务端在此次性能优化过程中做的工作,供大家参考讨论。
|
4月前
|
小程序 前端开发
微信小程序商城,微信小程序微店 【毕业设计参考项目】
文章推荐了一个微信小程序商城项目作为毕业设计参考,该项目在Github上获得18.2k星,提供了详细的使用教程和前端页面实现,适合学习微信小程序开发和作为毕业设计项目。
微信小程序商城,微信小程序微店 【毕业设计参考项目】
|
4月前
|
前端开发
一键复制微信聊天框效果:HTML+CSS让网页聊天更生动!
一键复制微信聊天框效果:HTML+CSS让网页聊天更生动!
|
2月前
|
JSON 小程序 JavaScript
uni-app开发微信小程序的报错[渲染层错误]排查及解决
uni-app开发微信小程序的报错[渲染层错误]排查及解决
625 7