在js代码拼接dom对象到页面上的模板总结


Posted in Javascript onOctober 21, 2018

每次在js代码里面想动态的拼个dom,然后append到页面上,都是各种麻烦,
要是可以直接在jsp页面弄个隐藏的model那是很好的,用js方法里面的clone方法也是很好的,还可以给不同部分set值。
为了以后简单点,我就把模板摆着,方便后面用得着的时候,复制粘贴。

function fillDialog(dataArray) {
  var target = $("#dialogTarget");
  target.empty();
  for (var i = 0; i < dataArray.length; i++) {
    var label = $('<label class="control-label" style="width: auto; text-align: left;"></label>');
    label.text("" + dataArray[i].channelName);
    var input = $("<input type=\"text\"/>");
    input.prop("name", "checkbox");
    input.prop("type", "checkbox");
    input.prop("value", dataArray[i].id);
    if (dataArray[i].showInUserStatistic) {
      input.prop("checked", "true");
    }
    label.prepend(input);
    target.append(label);
  }
}
var trs = "";
for (var i = 0; i < dataArray.length; i++) {
  var branchBank = dataArray[i].branch;
  var newUser = dataArray[i].newUserNum;
  var netBoostUser = dataArray[i].netBoostUserNum;
  var closeUser = dataArray[i].closeUserNum;
  var activeUser = dataArray[i].activeUserNum;
  var index = activeUser.indexOf(".");
  if (index > 0) {
    //去分行活跃用户数的小数部分如:11.0 ---> 11
    activeUser = activeUser.substring(0, index);
   }
   trs += "<tr><td title='" + branchBank + "'>" + branchBank + "</td>";
   trs += "<td title='" + newUser + "'>" + newUser + "</td>";
   trs += "<td title='" + netBoostUser + "'>" + netBoostUser + "</td>";
   trs += "<td title='" + closeUser + "'>" + closeUser + "</td>";
   trs += "<td title='" + activeUser + "'>" + activeUser + "</td>";
   trs += "</tr>";
 }
 newList.append("<tbody>" + trs + "</tbody>");
 tableChart.append(newList.show());
var $metric = $("#metric");
$metric.empty();
var optGroup0 = $("<optgroup label='常用指标'>");
var optGroup1 = $("<optgroup label='不常用指标'>");
var optGroup2 = $("<optgroup label='未分组指标'>");
for(var i=0; i<allMetricSources.length; i++) {
var m = allMetricSources[i];
if( m != null && (m.type == stream_type || m.type == 2)){
  var option = $("<option ></option>");
  option.attr("value", m.metric);
  option.attr("data_type", m.data_type);
  option.attr("unit", m.unit);
  option.html(m.title);
  if (m.groupType == 0) {
  optGroup0.append(option);
  } else if (m.groupType == 1) {
  optGroup1.append(option);
  } else {
  optGroup2.append(option);
  }
 }
}
$metric.append(optGroup0);
$metric.append(optGroup1);
$metric.append(optGroup2);
if(metric != undefined){
  $metric.val(metric);
}
$metric.trigger("chosen:updated");
function fillRecoveryTable(data) {
  var $tableBody = $("#recoveryTable").find("tbody");
  $tableBody.empty();
  var trs = "";
  for (var i = 0; i < data.length; i++) {
    var recovery = data[i];
    trs += "<tr><td >" + recovery.fileName + "</td>";
    trs += "<td >" + recovery.timeString + "</td>";
    trs += "<td >" + (recovery.result ? "成功" : "失败") + "</td>";
    trs += "<td >" +
      "<a onclick=\"removeRecovery('" + recovery.id + "');\" class=\"icon-trash option\" title=\"删除\"></a>" +
      "<a onclick=\"doRecovery('" + recovery.id + "');\" class=\"icon-cog option\" title=\"一键恢复\" ></a></td>";
    trs += "</tr>";
  }
  $tableBody.append(trs);
}

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对三水点靠木的支持。如果你想了解更多相关内容请查看下面相关链接

Javascript 相关文章推荐
js实现键盘控制DIV移动的方法
Jan 10 Javascript
关于在vue-cli中使用微信自动登录和分享的实例
Jun 22 Javascript
Bootstrap模态框插入视频的实现代码
Jun 25 Javascript
es6新特性之 class 基本用法解析
May 05 Javascript
详解webpack import()动态加载模块踩坑
Jul 17 Javascript
教你如何编写Vue.js的单元测试的方法
Oct 17 Javascript
JavaScript实现的滚动公告特效【基于jQuery】
Jul 10 jQuery
react-native聊天室|RN版聊天App仿微信实例|RN仿微信界面
Nov 12 Javascript
微信公众号H5之微信分享常见错误和问题(小结)
Nov 14 Javascript
Vue组件化开发之通用型弹出框的实现
Feb 28 Javascript
关于angular引入ng-zorro的问题浅析
Sep 09 Javascript
js实现复制粘贴的两种方法
Dec 04 Javascript
如何安装控制器JavaScript生成插件详解
Oct 21 #Javascript
Node.js中的不安全跳转如何防御详解
Oct 21 #Javascript
详解Axios 如何取消已发送的请求
Oct 20 #Javascript
使用Vue做一个简单的todo应用的三种方式的示例代码
Oct 20 #Javascript
Iview Table组件中各种组件扩展的使用
Oct 20 #Javascript
详解webpack打包第三方类库的正确姿势
Oct 20 #Javascript
详解ES6 Promise对象then方法链式调用
Oct 20 #Javascript
You might like
PHP实现显示照片exif信息的方法
2014/07/11 PHP
PHP调试的强悍利器之PHPDBG
2016/02/22 PHP
(JS实现)MapBar中坐标的加密和解密的脚本
2007/05/16 Javascript
JavaScript通过join函数连接数组里所有元素的方法
2015/03/20 Javascript
jQuery实现图片左右滚动特效
2020/04/20 Javascript
JavaScript的removeChild()函数用法详解
2015/12/27 Javascript
微信小程序 支付简单实例及注意事项
2017/01/06 Javascript
js实现类bootstrap模态框动画
2017/02/07 Javascript
Vue.set()实现数据动态响应的方法
2018/02/07 Javascript
Vue的elementUI实现自定义主题方法
2018/02/23 Javascript
js提取中文拼音首字母的封装工具类
2018/03/12 Javascript
pandas修改DataFrame列名的方法
2018/04/08 Python
pycharm使用matplotlib.pyplot不显示图形的解决方法
2018/10/28 Python
关于python下cv.waitKey无响应的原因及解决方法
2019/01/10 Python
python找出一个列表中相同元素的多个索引实例
2019/06/11 Python
基于python 微信小程序之获取已存在模板消息列表
2019/08/05 Python
解决python 3 urllib 没有 urlencode 属性的问题
2019/08/22 Python
详解python3中用HTMLTestRunner.py报ImportError: No module named 'StringIO'如何解决
2019/08/27 Python
tensorflow 初始化未初始化的变量实例
2020/02/06 Python
完美解决pyinstaller打包报错找不到依赖pypiwin32或pywin32-ctypes的错误
2020/04/01 Python
Python openpyxl 插入折线图实例
2020/04/17 Python
python logging通过json文件配置的步骤
2020/04/27 Python
基于python图书馆管理系统设计实例详解
2020/08/05 Python
python中yield的用法详解
2021/01/13 Python
详解Html5微信支付爬坑之路
2018/07/24 HTML / CSS
去加拿大的旅行和假期:Canadian Affair
2016/10/25 全球购物
英国领先的葡萄酒专家:Majestic Wine
2017/05/30 全球购物
写出SQL四条最基本的数据操作语句(DML)
2012/12/12 面试题
铭立家具面试题
2012/12/06 面试题
教师实习自我鉴定
2013/12/13 职场文书
宿舍违规用电检讨书
2014/02/16 职场文书
经理秘书求职自荐信范文
2014/03/23 职场文书
研究生导师评语
2014/12/31 职场文书
教你使用Pandas直接核算Excel中快递费用
2021/05/12 Python
浅谈JavaScript浅拷贝和深拷贝
2021/11/07 Javascript
开发者首先否认《遗弃》被取消的传言
2022/04/11 其他游戏