smartClient 2--可视化组件

2024-06-20 01:38

本文主要是介绍smartClient 2--可视化组件,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、功能:
1、标准功能
Foundation Services
Foundation Components
Event Handling
Controls
Forms
Grids
Trees
Layout
DataBinding
Themes/Skins

 

2、扩展功能
SmartClientServer  //包含Java类库的集成后端
Analytics
Real-Time Messaging
Network Performance

 

二、开发语言
1、XML
2、JavaScript(推荐使用)
三、资源: https://www.smartclient.com/smartclient/showcase/?id=formLayoutFilling&skin=Simplicity&fontIncrease=1&sizeIncrease=2
四、样式修改:
1、更换系统皮肤:引用不同的css包
2、自定义样式:
a. 同系统皮肤自成一个文件夹的形式一样,新建文件夹(如BrushedMetal),将最接近目的皮肤的文件夹里的内容(包含skin_styles.css   images/   load_skin.js)copy进新文件夹
b. 在首页入口文件中引用的皮肤样式文件中引入新建样式
c. 在skin_styles.css和load_skin.js的文件底部重写样式(找到某个需要修改的类,例如button,在后面写上覆盖样式即可)
3、重构独立的组件内部的样式
五、可视化组件
1、独立组件
a. 识别组件(引用组件方式)
采用 id:   默认组件的id是全局命名空间下的(所以命名id时,需要注意唯一性)
isc.Label.create({ID: "helloWorldLabel",contents: "hello world"
});

 

自动分配id,规则:isc_ClassName_ID_#
var helloWorldLabel = isc.Label.create({ contents: "Hello World" 
});
b. 组件布局:通过设置组件属性的方式创建组件    注意:如果不是在组件中定义组件布局(如下),而是在CSS/HTML中直接修改,则必须手动做好浏览器兼容问题
isc.Label.create({top: 10,    //int,相对于该组件的containerleft: 10,width: 10,    //int | string "50%", 默认100contents: "hello world",overflow: "hidden | scroll | auto",position: "relative | absolute | fixed"    //默认absolute,相对于该组件的container
});

    

c. 组件的渲染、隐藏、显示
autoDraw: true | false;    //默认TRUE,即create即显示,如果FALSE,则需要js控制: hiddenBtn.show();
show();
hide();eg.
isc.Button.create({ID: 'hiddenBtn',title: 'Hidden',autoDraw: false
});

       

d. 组件的事件
click recordClick change tabSelectedeg. 
isc.Button.create({ID: "clickBtn",title: "click me",click: function(){},click: "isc.warn('button was clicked')",click: "clickFn()"
});
function clickFn() {......}

 

e. 数据绑定
字段field:包括组件字段 和 数据源字段
//网格的形式显示
isc.ListGrid.create({ID: "contactList",left: 50, top: 50,width: 300,fields: [{name: "salutation", title: "Title"},    //name 是关联数据库中的value,title是显示文字(在表单控件中是作为label显示,在button中是作为button上的文字显示){name: "firstname", title: "First Name"}      ]
});data: [{salutation: "Ms", firstname: "Kathy"},{salutation: "Ms", firstname: "Kathy"},
];//DynamicForm的格式显示
isc.DynamicForm.create({......同上});

 

g. 表单控件    注意:一旦组件绑定了数据源,组件将会根据数据源的数据格式自动匹配表单控件《即不需要fields字段,会自动匹配并绑定数据》。但是通常fields和
dataSource共存,行使不同的职责( 表单字段(field)或者说控件的默认类型(editorType)是text )
//editorType: text select date checkbox radioGroup textArea
isc.DynamicForm.create({ID: "contactForm",......,fields: [{name: "salutation", title: "Title", editorType: "select"},    {name: "firstname", title: "First Name", editorType: "date"},{name: "gender", title: "gender", editorType: "radioGroup", valueMap: ["female", "male"]}    //valueMap 是数组形式的radio的选项显示文字
   ]
});

 

h. 数据源(数据源的定义格式类似SQL数据存储格式,区别在于:1)存储方式是XML或者js;2)必须定义数据类型;......)
<DataSource ID="contactsDS">
<fields><field primaryKey="true" name="id" hidden="true" type="sequence" /><field name="salutation" title="Title" type="text" ><valueMap><value>Ms</value><value>Mr</value><value>Mrs</value></valueMap></field><field name="firstname" title="First Name" type="text" /><field name="lastname" title="Last Name" type="text" /><field name="birthday" title="Birthday" type="date" /><field name="employment" title="Status" type="text"><valueMap><value>Employed</value><value>Unemployed</value></valueMap></field><field name="bio" title="Bio" type="text" length="2000" /><field name="followup" title="Follow up" type="boolean" />
</fields>
</DataSource>

 

h1.    xml格式的DataSource创建好之后,在js文件里引入该文件,并通过 dataSource 属性,即可绑定数据(此时用dataSource代替了fields属性)
<isomorphic:loadDS ID="contactsDS" /><%@ taglib uri="isomorphic" prefix="isomorphic" %>
<HTML>
<HEAD><isomorphic:loadISC />
</HEAD>
<BODY>
<SCRIPT><isomorphic:loadDS ID="contactsDS" />
    isc.ListGrid.create({ID: "contactsList",left: 50, top: 50,width: 500,dataSource: contactsDS});isc.DynamicForm.create({ID: "contactsForm",left: 50, top: 200,width: 300,dataSource: contactsDS});
</SCRIPT>
</BODY>
</HTML>

 

h2.    字段属性(fields的属性type)和表单控件一一对应规则:
Field attribute                    Form control
valueMap provided        SelectItem (dropdown)
type:"boolean"                CheckboxItem (checkbox)
type:"date"                        DateItem (date control)
length > 255                    TextAreaItem (large text box)

 

h3.    数据源的操作
//以下方法均包含可选三个参数:dataObject,callback,propertiseObject
fetchData();
filterData();
addData();
updateData();
removeData();//使用方法: 1)直接在数据源中使用    2)直接在组件做数据绑定的时候使用
contactDS.addData({salutation: "Mr", firstname: "Steven", lastname: "Hua"},"say("hello")",{prompt: "add new contact..."}
);orcontactsList.fetchData({lastname: "nihao"}
);

 

h4.    调用组件方法操作数据
editRecord();
editNewRecord();
saveData();

 

 

这篇关于smartClient 2--可视化组件的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1076736

相关文章

Spring组件实例化扩展点之InstantiationAwareBeanPostProcessor使用场景解析

《Spring组件实例化扩展点之InstantiationAwareBeanPostProcessor使用场景解析》InstantiationAwareBeanPostProcessor是Spring... 目录一、什么是InstantiationAwareBeanPostProcessor?二、核心方法解

Python数据分析与可视化的全面指南(从数据清洗到图表呈现)

《Python数据分析与可视化的全面指南(从数据清洗到图表呈现)》Python是数据分析与可视化领域中最受欢迎的编程语言之一,凭借其丰富的库和工具,Python能够帮助我们快速处理、分析数据并生成高质... 目录一、数据采集与初步探索二、数据清洗的七种武器1. 缺失值处理策略2. 异常值检测与修正3. 数据

使用Python和Matplotlib实现可视化字体轮廓(从路径数据到矢量图形)

《使用Python和Matplotlib实现可视化字体轮廓(从路径数据到矢量图形)》字体设计和矢量图形处理是编程中一个有趣且实用的领域,通过Python的matplotlib库,我们可以轻松将字体轮廓... 目录背景知识字体轮廓的表示实现步骤1. 安装依赖库2. 准备数据3. 解析路径指令4. 绘制图形关键

C++ RabbitMq消息队列组件详解

《C++RabbitMq消息队列组件详解》:本文主要介绍C++RabbitMq消息队列组件的相关知识,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1. RabbitMq介绍2. 安装RabbitMQ3. 安装 RabbitMQ 的 C++客户端库4. A

8种快速易用的Python Matplotlib数据可视化方法汇总(附源码)

《8种快速易用的PythonMatplotlib数据可视化方法汇总(附源码)》你是否曾经面对一堆复杂的数据,却不知道如何让它们变得直观易懂?别慌,Python的Matplotlib库是你数据可视化的... 目录引言1. 折线图(Line Plot)——趋势分析2. 柱状图(Bar Chart)——对比分析3

使用Vue-ECharts实现数据可视化图表功能

《使用Vue-ECharts实现数据可视化图表功能》在前端开发中,经常会遇到需要展示数据可视化的需求,比如柱状图、折线图、饼图等,这类需求不仅要求我们准确地将数据呈现出来,还需要兼顾美观与交互体验,所... 目录前言为什么选择 vue-ECharts?1. 基于 ECharts,功能强大2. 更符合 Vue

PyQt6中QMainWindow组件的使用详解

《PyQt6中QMainWindow组件的使用详解》QMainWindow是PyQt6中用于构建桌面应用程序的基础组件,本文主要介绍了PyQt6中QMainWindow组件的使用,具有一定的参考价值,... 目录1. QMainWindow 组php件概述2. 使用 QMainWindow3. QMainW

Git可视化管理工具(SourceTree)使用操作大全经典

《Git可视化管理工具(SourceTree)使用操作大全经典》本文详细介绍了SourceTree作为Git可视化管理工具的常用操作,包括连接远程仓库、添加SSH密钥、克隆仓库、设置默认项目目录、代码... 目录前言:连接Gitee or github,获取代码:在SourceTree中添加SSH密钥:Cl

Pandas中统计汇总可视化函数plot()的使用

《Pandas中统计汇总可视化函数plot()的使用》Pandas提供了许多强大的数据处理和分析功能,其中plot()函数就是其可视化功能的一个重要组成部分,本文主要介绍了Pandas中统计汇总可视化... 目录一、plot()函数简介二、plot()函数的基本用法三、plot()函数的参数详解四、使用pl

使用Python实现矢量路径的压缩、解压与可视化

《使用Python实现矢量路径的压缩、解压与可视化》在图形设计和Web开发中,矢量路径数据的高效存储与传输至关重要,本文将通过一个Python示例,展示如何将复杂的矢量路径命令序列压缩为JSON格式,... 目录引言核心功能概述1. 路径命令解析2. 路径数据压缩3. 路径数据解压4. 可视化代码实现详解1