data组件特殊规则怎么用

html-css010

data组件特殊规则怎么用,第1张

1 初始化加载状态

Data组件上有两个关于初始化加载状态属性:autoLoad、autoNew,表示当功能页面打开后data组件的状态,两个属性是互斥的;

当autoLoad=true时,Data组件在model的onModelConstructing时执行open操作,当autoNew=true时,Data组件在model的

onModelConstructing时执行newData操作;

注:data定义的静态数据需要autoLoad=true才进行加载,否则需要主动调用open方法加载;

2 Data组件相互依赖时候注意顺序

Data1依赖Data2的时候,注意Data2要放在Data1前面;可以在Model组件中拖动;

3 Data组件不仅可以感知数值,还可以感知数据类型;

比如:input组件绑定的是Date型,input组件点击后会显示日期选择框;

4 规则表达式,以“js:”开头;

5 环境变量

$model:当前页面模型对象;

$data:当前数据对象;

$row:当前行对象;

$col:当前列名;

$rowID:当前行ID;

上下文对象

表达式上下文的实现机制:基于JS的with语句

数据集规则:$data;

字段规则:$row;

6 Data组件可以直接使用“$model.xxxData”直接访问;

注意:在Data构造方法内,不允许出现this.xxxData=xxx否则,会冲突!

7 ref、val、label区别

ref:绑定数据组件,返回可监控对象;

val:返回数值,用于表达式计算;

label:返回列的显示名称;

Data和Data.Row上都存在ref、val、label三个方法,区别:

Data:

Data.ref(col, row)

Data.val(col, row)

Data.label(col)

Data.Row:

Row.ref(col)

Row.val(col, value)

Row.label(col)

8 表达式中的聚合函数

number data.count(function filterCallback)

number data.sum(string column, function filterCallback)

number data.avg(string column, function filterCallback)

number data.min(string column, function filterCallback)

number data.max(string column, function filterCallback)

9 在表达式中使用的JS对象和函数

可以使用任何“可以访问到的JS对象和函数”

JS全局函数和对象;

window对象;

jQuery:$=window.$;

justep工具类:justep=window.justep;

环境变量:$model, $data, $row……;

获取页面组件

获取当前页面上的X5组件对象:$model.comp(xid|element);

获取当前页面上的HTML原生对象:$model.getElementByXid(xid);

基于$model自定义JS函数

自定义函数:在页面的JS文件中,为Model增加函数,通过$model访问;

自定义函数库:在页面的JS文件中,引入JS函数库,将函数库对象设置为Model变量,通过$model访问;

10 绑定表达式

环境变量

$model:当前页面模型对象;

$element:当前HTML元素对象;

$index:当前行索引,仅当组件在list或foreach内有效(注意,$index是一个函数);

$object:当前上下文对象;

bind-ref、bind-labelRef:绑定数据列的ref感知对象;针对x5的组件,双向数据感知;能感知数据类型,比如string、number、

date,会做类型校验;

其他数据绑定(多用于HTML原生组件)

bind-value:适用于input、password、select、textarea;单向感知;

bind-checked:适用于checkbox、radio;

bind-text:适用于span、label、em;

面向数据编程:编程重心在数据上,而不是在视图上;

11 状态相关绑定(boolean表达式)

bind-visible:显示;

bind-hasFocus:是否获得输入焦点;

bind-enabled:可用;

bind-disabled:禁用(优先);

12 绑定样式(JSON表达式)

bind-style: {'backgroundColor':

foodData.val('fPrice')>30?'red':null}

bind-css: {'text-danger':foodData.val('fPrice')>30}

13 其他HTML属性绑定

bind-attr-src:

bind-attr-href:

bind-attr-title

bind-attr-xxxx

14 控制类数据绑定

bind-if:当前组件的内容是否创建;

bind-ifnot:同上;

bind-with:指定内部组件绑定表达式的上下文对象($object);

bind-foreach:按指定可监控数组中的数据项,创建多份组件内容,每一份组件内容的上下文对象分别对应数组的每一个数据项;

15 其他绑定

bind-html:动态创建innerHTML;

bind-uniqueName:动态创建唯一的name;

16 过滤表达式

List的filter属性过滤可显示的数据项;

17 事件编程

event.bindingContext

$object:model、row或其他

在list组件内:$object=row

在bind-with环境内:$object=指定的上下文对象

在bind-foreach环境内:$object=foreach的数据项

当前事件监听对象

on事件:event.source,X5组件对象;还可以绑定操作;

bind事件:event.currenttarget,HTML元素对象;

Vue3对CSS支持加入了更多的特性支持,这样的话,我们在项目当中使用CSS就变得更加灵活了,来吧我们直接上干货

在style的标签上加一个module的属性,这样style里面的内容就会被编译成CSS Modules(模块),默认情况下,我们可以在模板代码里,或者JS里通过$style拿到所有样式属性并使用

我们也可以给CSS Modules自定义一个名称,在style的module属性设置一个名称就可以了,这样的话在模板和JS里就通过自定义的名称来引入CSS里的属性

与组合式 API 一同使用,注入的类可以通过 useCssModule API 在 setup() 和.success { color: #090}

可以通过 v-bind 这一 CSS 函数将 CSS 的值关联到动态的组件状态上

这个语法同样也适用于