国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

xmlplus組件設計系列之列表(4)

2024-05-06 15:17:57
字體:
來源:轉載
供稿:網友

列表組件是極其常用的一類組件,是許多視圖組件系統的必須包含的。列表可以做的很簡單,只顯示簡潔的內容。列表也可以做的很復雜,用于展示非常豐富的內容。

組成元素

列表離不開列表項以及包含列表項的容器。下面是最簡單的列表組件,它包含一個列表項組件 Item 以及一個列表項容器組件 List。

Item: { xml: "<li id='item'/>"},List: { xml: "<ul id='list'/>"}

此列表組件盡管簡單,但所構建的框架為我們的繼續擴展奠定了基礎。

動態操作

如上定義的列表組件的最基本的用法如下所示。這種用法與原生列表標簽的用法沒什么區別。我們將進行做進一步的改造。

Example: { xml: "<List id='example'>/  <Item>Item 1</Item>/  <Item>Item 2</Item>/  </List>"}

列表組件普遍包含添加、刪除以及修改這三種操作。為簡單起見,不妨先來實現這些操作。由于我們定義的列表項足夠的簡單,所以這里不再定義新的操作接口,而直接使用系統接口。

Example: { xml: "<div id='example'>/  <List id='list'/>/  <button id='append'>append</button>/  <button id='remove'>remove</button>/  <button id='modify'>modify</button>/  </div>", fun: function (sys, items, opts) { sys.append.on("click", function() {  sys.list.append("Item").text("Item 1"); }); sys.remove.on("click", function() {  sys.list.first() && sys.list.first().remove(); }); sys.modify.on("click", function() {  sys.list.first() && sys.list.first().text("Item 2"); }); }}

該示例使用列表的系統函數 append 來追加列表項,并使用列表項的系統函數 remove 來移除列表項,同時還使用列表項的系統函數 text 來修改列表項的數據。

由于上面的列表項所包含的是簡單的文本數據,所以上面示例使用 text 函數來操作數據是適合的。現在給出一個包含較復雜數據的列表項,該列表項額外定義了數據操作接口。

Item: { xml: "<li id='item'>/  <span id='color'>red</span>  <span id='shape'>square</span>  </li>", fun: function (sys, items, opts) { function getValue() {  return {color: sys.color.text(), shape: sys.shape.text()}; } function setValue(obj) {  sys.color.text(obj.color);  sys.shape.text(obj.shape); } return Object.defineProperty({}, "data", { get: getValue, set: setValue}); }}

下面是包含新列表項的列表操作的一個示例。其中對于組件的追加與刪除還可以使用系統提供的函數,但對于數據的獲取與修正就只能使用新定義的接口了。

Example: { xml: "<div id='example'>/  <List id='list'/>/  <button id='append'>append</button>/  <button id='remove'>remove</button>/  <button id='modify'>modify</button>/  </List>", fun: function (sys, items, opts) { sys.append.on("click", function() {  sys.list.append("Item"); }); sys.remove.on("click", function() {  sys.list.first() && sys.list.first().remove(); }); sys.modify.on("click", function() {  sys.list.first() && items.list.first().data = {color: "blue", shape: "rectangle"}; }); }}            
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 新晃| 玉林市| 周至县| 日土县| 肃北| 梨树县| 景东| 永康市| 湄潭县| 海林市| 岑溪市| 临武县| 衡山县| 邵阳市| 南汇区| 科尔| 盐山县| 南溪县| 赞皇县| 玛纳斯县| 泰和县| 乐山市| 根河市| 星子县| 师宗县| 福泉市| 库伦旗| 博乐市| 南投县| 柘城县| 贵港市| 上犹县| 浦东新区| 河北区| 公安县| 黄浦区| 虞城县| 曲阜市| 陈巴尔虎旗| 张家口市| 兰溪市|