美文网首页Weex
Weex语法——显示逻辑控制器

Weex语法——显示逻辑控制器

作者: 阿凡提说AI | 来源:发表于2017-01-21 14:41 被阅读8次

Weex前端语义支持通过两种特殊属性(if和repeat)的设置来确定组件的显示状态,这会使得整个页面布局显得更加灵活。

if

通过设置if属性值,可以控制当前组件节点的显示状态。如果设为true,则会将当前节点置于DOM中渲染,反之则会从DOM中移除。

<template>
    <container>
        <text onclick="toggle">Toggle</text>
        <image src="..." if="{{shown}}"></image>
    </container>
    </template>
 
    <script>
        module.exports = {
        data: {
            shown: true
        },
        methods: {
        toggle: function () {
            this.shown = !this.shown
        }
        }
    }
    </script>

repeat

repeat属性用于控制具有相同样式或属性的组件节点做重复渲染。它绑定的数据类型必须为数组,其中每个数组项的属性会分别绑定到需要重复渲染的各子组件上。

 <template>
    <container>
        <container repeat="{{list}}" class="{{gender}}">
            <image src="{{avatar}}"></image>
            <text>{{nickname}}</text>
        </container>
    </container>
    </template>
 
    <style>
    .male {...}
    .female {...}
    </style>
 
    <script>
    module.exports = {
        data: {
            list: [
            {gender: 'male', nickname: 'Li Lei', avatar: '...'},
            {gender: 'female', nickname: 'Han Meimei', avatar: '...'},
         ...
        ]
     }
    }
</script>

此外,weex同样支持不在repeat数组中的数据绑定到重复渲染的组件节点上。

<template>
    <container>
        <container repeat="{{list}}" class="{{gender}}">
        <image src="{{avatar}}"></image>
        <text>{{nickname}} - {{group}}</text>
        </container>
    </container>
    </template>
 
    <style>
    .male {...}
    .female {...}
    </style>
 
    <script>
    module.exports = {
        data: {
            group: '...',
             list: [
                {gender: 'male', nickname: 'Li Lei', avatar: '...'},
                {gender: 'female', nickname: 'Han Meimei', avatar: '...'},
                 ...
            ]
        }
    }
    </script>

repeat属性扩展

使用 $index 获取当前节点所绑定的数据在repeat数组中的索引值.
例如:

 <div repeat="{{list}}">
        <text>No. {{$index + 1}}</text>
    <div>

获取repeat数组的属性值.
例如:

<div repeat="{{v in list}}">
        <text>
              No. {{$index + 1}}, {{v.nickname}}
        </text>
 </div>

<div repeat="{{(k, v) in list}}">
      <text>No. {{k + 1}}, {{v.nickname}}</text>
    </div>

使用 track-by 追踪特殊的属性
通常情况下,当更新repeat数组时,所有数组元素关联的组件节点都会被重新渲染。如果其中部分节点的数据在更新前后未发生变更,那么最好是让这些节点保持原样,仅更新数据有变化的节点,weex提供了track-by属性能帮您轻松搞定。
注意: track-by属性的设置不支持数据绑定的方式

<template>
    <container>
        <container repeat="{{list}}" track-by="nickname" class="{{gender}}">
            <image src="{{avatar}}"></image>
            <text>{{nickname}} - {{group}}</text>
        </container>
    </container>
    </template>

如前所述,当更新repeat数组时,如果检测到属性nickname的值前后一致,那么它所绑定的子节点将不被重新渲染。

简化写法

对于if和repeat的使用,可以简化处理,即if="show"和if="{{show}}"所表达的前端语义相同。

<template>
    <container>
        <text if="shown">Hello</text>
        <text if="{{shown}}">Hello</text>
    </container>
    </template>
 
    <script>
        module.exports = {
        data: function () {return {shown: true}}
    }
    </script>

很显然,这两个text文本会被同时显示出来。

相关文章

  • Weex语法——显示逻辑控制器

    Weex前端语义支持通过两种特殊属性(if和repeat)的设置来确定组件的显示状态,这会使得整个页面布局显得更加...

  • Weex语法——渲染逻辑控制器

    append append属性没有做数据绑定的工作。它不会改变最终的渲染效果。但是此属性确定是以一整棵树或子节点的...

  • MVVM之网络请求

    1.控制器:显示视图; 2.VM逻辑处理

  • Android架构

    MVC mvc model view controller 模式视图控制器 M: 业务逻辑处理 V:处理数据显示的...

  • 前端架构:MVC以及MVVM MVP介绍

    1、mvc   Model-View-Controller(模型-视图-控制器):用一种业务逻辑、数据、界面显示分...

  • weex打包Android和IOS

    1.安装weex 安装结束后你可以直接使用 weex help 命令验证是否安装成功,它会显示 weex 支持的所...

  • 什么是MVC

    MVC是Model(模型) View (视图)Controller(控制器)缩写,是用一种业务逻辑、数据与界面显示...

  • 逻辑控制器

    JMeter逻辑控制器可以对元件的执行逻辑进行控制,除仅一次控制器外,其他控制器下可以嵌套别的种类的逻辑控制器。 ...

  • Weex 语法综述

    Weex页面由