如何在 JS 中嵌入大量 HTML 代码 --更新2017-10-10 16:37:09
一、一般方式
方式1:\ 要写在标签后面,看例子 var longString = "\
------------------------\
------------------------\
...
------------------------\
";
var toast;
toast = '\
<div id="toast" style="display:none;">\
<div class="weui_mask_transparent"></div>\
<div class="weui_toast">\
<i class="weui_icon_toast"></i>\
<p class="weui_toast_content">' + msg + '</p>\
</div>\
</div>\
';
$('').append(toast);
方式2:+ 要看清楚哪些地方加双引号和单引号
var longString = '------------------------' +
'------------------------' +
...
'------------------------';
for (var x in imgstrs) {
var $preview = $('<div class="col-xs-2 col-md-2">'
+'<a href="#" class="thumbnail"> <img id="tuNO'+x
+'"+ src="/images/'+imgstrs[x]
+'" width="55px" height="55px"></img></a></div>');
$('#crudmodal_modify #show_images').append($preview); }
方式3:String.concat
''.concat(
'-----------------------------',
'-----------------------------',
...
'-----------------------------',
);
方式4:Array.join
[
'-----------------------------',
'-----------------------------',
...
'-----------------------------',
].join('');
二 、无法将js中的数据 动态加上去。 如你想拼接 src="/images/"+imgstrs[x] 这样在html语法是错误的。《==这句话是错误的,之前本人理解不深
如果你看懂了,动态数据都可以通过方式1 和2 拼接。
三、通过模板
例子1、
<script type="text/template" id="html_template">
<div>HTML代码</div>
</script> <script type="text/javascript">
var html = document.getElementById('html_template').innerHTML;</script>
这种方式的好处就是可以保持代码缩进,易读易修改,、
例子2、 ===来自个人 vue中添加的模板
<!-- 首页模版 -->
<script id="home_tmpl" type="text/v-template">
<img src="assets/img/home.png" alt="" width="100%">
</script>
<!-- 列表模版 -->
<script id="list_tmpl" type="text/v-template">
<!-- 这里的内容不会显示到界面上 -->
<div class="list">
<ol>
<li v-for="item in list">
<a v-link="{ name: 'item', params: { id: item.id } }">
<span class="num">{{pad(item.id, 3)}}</span>
<div class="info">
<h3 class="title">{{item.name}}</h3>
<span class="artist">{{item.artist}}</span>
</div>
<span class="duration">{{convert(item.duration)}}</span>
<div class="photo"><img :src="item.poster" alt="{{item.artist}}"></div>
</a>
</li>
</ol>
</div>
</script>
通过这样取出
var loadTemplate = function (name) {
return document.getElementById(name + '_tmpl').innerHTML
}
四、拓展,js添加节点和 jq添加节点对比
例子1、被注释掉的就是js代码
$(function () {
// var box = document.getElementById("box");
//
// var a = document.createElement("a");
// box.appendChild(a);
// a.setAttribute("href", "http://web.itcast.cn");
// a.setAttribute("target", "_blank");
// a.innerHTML = "传智大前端";
$("#box").append('<a href="http://web.itcast.cn" target="_blank">传智大前端</a>');
});
例子2、为了添加成下面子节点,被屏蔽的是js代码,可以看出js比较麻烦
<tr >
<td style="text-align: center;">序号</td>
<td style="text-align: center;">内容</td>
<td style="text-align: center;">价格</td>
</tr>
// 处理改装列表 子表格
var gaizhuangxinxi, gaizhuangxinxi_tr, gaizhuangxinxi_id_td, gaizhuangxinxi_content_td, gaizhuangxinxi_price_td;
var gaizhuangxinxislen = data.data.gaiZhuangXinXis.length;
$('#gaizhuangxinxi_list input')
$('#gaizhuangxinxi_list').empty(); // for (var i = 0; i < gaizhuangxinxislen; i++) {
// gaizhuangxinxi = data.data.gaiZhuangXinXis[i];
// gaizhuangxinxi_tr = document.createElement("tr");
// gaizhuangxinxi_id_td = document.createElement("td");
// gaizhuangxinxi_content_td = document
// .createElement("td");
// gaizhuangxinxi_price_td = document
// .createElement("td");
// gaizhuangxinxi_tr.appendChild(gaizhuangxinxi_id_td);
// gaizhuangxinxi_tr
// .appendChild(gaizhuangxinxi_content_td);
// gaizhuangxinxi_tr
// .appendChild(gaizhuangxinxi_price_td);
// gaizhuangxinxi_id_td.innerHTML = gaizhuangxinxi.id;
// gaizhuangxinxi_content_td.innerHTML = gaizhuangxinxi.gaiZhuangLeiXing;
// gaizhuangxinxi_price_td.innerHTML = gaizhuangxinxi.danJia;
// $('#gaizhuangxinxi_list').append(gaizhuangxinxi_tr);
// }
for (var i = 0; i < gaizhuangxinxislen; i++) {
gaizhuangxinxi = data.data.gaiZhuangXinXis[i];
gaizhuangxinxi_tr =$('<tr> <td style="text-align: center">'+gaizhuangxinxi.id
+'</td><td style="text-align: center">'+gaizhuangxinxi.gaiZhuangLeiXing
+'</td><td style="text-align: center">'
+gaizhuangxinxi.danJia+'</td></tr>');
$('#gaizhuangxinxi_list').append(gaizhuangxinxi_tr);
}
如何在 JS 中嵌入大量 HTML 代码 --更新2017-10-10 16:37:09的更多相关文章
- js中嵌入jsp(html)代码的双引号转换问题--事件没反应
下面是一段今天遇到问题的代码,select中写了onchange事件 ,在没有加转义的情况下,F12解析的代码是错乱的,双引号与内容中写的不一致,还会有空格出现,经过一段时间的摸索,发现在出错的地方加 ...
- 如何在JS中应用正则表达式
背景:在之前的随笔中写过C#中如何使用正则表达式,这篇随笔主要讲如何在js中应用正则表达式 如下代码: $("#zhengze").click(function () { var ...
- 如何在Word中排出漂亮的代码
引言 学数学和计算机,当然还是用LaTeX排版技术文章更方便.但有时候还是迫不得已需要用Word写作,另外Word其实也有Word的好处,比如细节上的修改要比LaTeX方便. 从Matlab高亮代码复 ...
- 如何在C或C++代码中嵌入ARM汇编代码
转载自:http://blog.csdn.net/roland_sun/article/details/42921131 大家知道,用C或者C++等高级语言编写的程序,会被编译器编译成最终的机器指令. ...
- 如何在 Go 中嵌入 Python
如果你看一下 新的 Datadog Agent,你可能会注意到大部分代码库是用 Go 编写的,尽管我们用来收集指标的检查仍然是用 Python 编写的.这大概是因为 Datadog Agent 是一个 ...
- Razor 在JS中嵌入后台变量
HTML 中定义全局变量 @{ int CurrentUserId =ViewBag.CurrentUserId; } JS中取值方式var CurrentUserId = parseInt(@Htm ...
- C# 如何在winform中嵌入Excel,内嵌Excel,word
近使用.net做一个小软件遇到一个问题,就是想实现把excel表格在winform中打开,同时可以操作,不单单是打开.或者就提取数据.在网上找了好多资料,发现这方面的资料比较少,即使有,都是旧版本的使 ...
- js技术之如何在JS中获取input的值
在JavaScript中获取input元素value的值: 方法一:var variations_number = $("#input的id名").val(); 1 <!DO ...
- JS中的常用的代码操作
本文件介绍常用的js代码的DOM操作.CSS操作.对象(Object对象.Array对象.Number对象.String对象.Math对象.JSON对象和Console对象)操作说明. 一.DOM树的 ...
随机推荐
- poj 2385 Apple Catching(记录结果再利用的动态规划)
传送门 https://www.cnblogs.com/violet-acmer/p/9852294.html 题意: 有两颗苹果树,在每一时刻只有其中一棵苹果树会掉苹果,而Bessie可以在很短的时 ...
- Constructor >> @Autowired >> @PostConstruct
从依赖注入的字面意思就可以知道,要将对象p注入到对象a,那么首先就必须得生成对象p与对象a,才能执行注入.所以,如果一个类A中有个成员变量p被@Autowired注解,那么@Autowired注入是发 ...
- (最长回文子串 线性DP) 51nod 1088 最长回文子串
输入一个字符串Str,输出Str里最长回文子串的长度. 回文串:指aba.abba.cccbccc.aaaa这种左右对称的字符串. 串的子串:一个串的子串指此(字符)串中连续的一部分字符构成的子(字符 ...
- 位掩码(BitMask)的介绍与使用
一.前言 位运算在我们实际开发中用得很少,主要原因还是它对于我们而言不好读.不好懂.也不好计算,如果不经常实践,很容易就生疏了.但实际上,位运算是一种很好的运算思想,它的优点自然是计算快,代码更少. ...
- Hadoop基础-MapReduce入门篇之编写简单的Wordcount测试代码
Hadoop基础-MapReduce入门篇之编写简单的Wordcount测试代码 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 本文主要是记录一写我在学习MapReduce时的一些 ...
- Tensorflow搞一个聊天机器人
catalogue . 前言 . 训练语料库 . 数据预处理 . 词汇转向量 . 训练 . 聊天机器人 - 验证效果 0. 前言 不是搞机器学习算法专业的,3个月前开始补了一些神经网络,卷积,神经网络 ...
- java虚拟机的内存模型
一.为什么要了解java虚拟机的内存模型 java虚拟机作为java代码运行的平台,是java技术的基石.了解java虚拟机的内存模型也就变得十分必要.它能帮助我们更好的了解java代码的运行机制,更 ...
- C#设计模式(9)——代理模式
1.代理模式介绍 在软件开发中有时会遇到不能直接使用对象的问题,如我们要使用的对象在进程外,甚至在远程的机器上,但是我们要使用这个对象的功能怎么办呢?代理模式就可以用来解决这个问题.举一个生活中的例子 ...
- tomcat 下配置ajax 跨域 tomcat font face 跨域 java跨域
tomcat ajax跨域和css字体 font face 跨域一样适用 CORS介绍 它在维基百科上的定义是:跨域资源共享(CORS )是一种网络浏览器的技术规范,它为Web服务器定义了一种方式 ...
- keytool导入导出多条目对比【原】
步骤一:生成orange.keystore和banana.keystore keytool -genkey -alias orange -keyalg RSA -keysize 1024 -keypa ...