js里怎么方便的输出大量的html

2012-04-24 21:17:10 +08:00
 sd4399340
是这样一种需求,我要在js读取api从数据库里拿大量数据,
然后动态生成很多div乱七八糟的,大量的html,怎么样方便点呢,
js文件里出现大量的html是不是不太雅观啊

我以前是在html里写一个隐藏的div,把框架搭好,然后js填充这个div,
然后把这个填充好的div给append到别处去,用完就隐藏掉,再用的时候再append到另外的地方

大家一般咋解决的?
5478 次点击
所在节点    JavaScript
20 条回复
lyxint
2012-04-24 21:26:13 +08:00
airyland
2012-04-24 21:27:17 +08:00
文本模板用<script type="text/template" id="template">some html {{data}}</script>写在html里。
用mustache之类的模板引擎render。
catfan
2012-04-24 21:37:11 +08:00
使用此方法建立fragment
var frag = document.createDocumentFragment();

在里面塞元素:
frag.appendChild(xxx);

然后把它append到需要的地方
document.getElementById('wrap').append(frag);
turing
2012-04-24 21:40:21 +08:00
https://github.com/janl/mustache.js
+1 使用有规则数据源,确定好DOM结构后按需渲染。
jjlovegrape
2012-04-24 21:47:41 +08:00
https://github.com/janl/mustache.js +1,在最近的一个项目中使用了mustache,感觉很KISS,配合backbone使用效果更佳。
http://coenraets.org/blog/2011/12/tutorial-html-templates-with-mustache-js/ 这边是个mustache.js的 tutorial,可能要翻墙。
rociiu
2012-04-24 21:47:56 +08:00
可以看看 backbone (http://documentcloud.github.com/backbone/) 轻量的前端MVC框架
sd4399340
2012-04-24 21:49:34 +08:00
@turing @lyxint 我也想过模板,这个在非node的环境下也可以用?
turing
2012-04-24 21:50:27 +08:00
@sd4399340 mustache可以完全用在客户端,支持js渲染的。
sd4399340
2012-04-24 21:52:15 +08:00
@rociiu 这个前段时间看过的,很好的东西,不过还没怎么懂~呵呵
POPOEVER
2012-04-24 21:55:02 +08:00
其实我跟你一样,我更懒,直接用 jQuery 的 html()+prepend() =_=
tioover
2012-04-24 22:10:22 +08:00
看了一下mustache
语法会和服务端的冲突,怎么解决?
jjlovegrape
2012-04-24 22:13:51 +08:00
@tioover 为什么会和服务端冲突呢?比较好的方式是,从服务端读取了JSON,然后render模板,模板支持用函数的方法填充,填充可以是{{someFunctiion}},这个函数里处理你想要的数据。{{{}}}这样使用填充的内容不会变转移。
lene
2012-04-24 22:18:48 +08:00
介不似那个谁么?学习学习~~~
zzNucker
2012-04-24 22:28:15 +08:00
@catfan 的方法是不在第三方框架介入的情况下比较高效的方法
tioover
2012-04-24 22:29:28 +08:00
@jjlovegrape 也对……
jamev5
2012-04-24 22:31:39 +08:00
@POPOEVER 彼此彼此,先在才知道还有这种办法,受教了。
sd4399340
2012-04-24 22:32:44 +08:00
@lene 矮油,这里你都玩啊~
paulguo
2012-08-30 22:34:31 +08:00
可以尝试下 Juicer(榨汁机,模板引擎 by Taobao UED):http://juicer.name ,性能较 Mustache 等出众很多。
kernel1983
2012-08-30 23:43:02 +08:00
js template, 由于现在underscore.js已经是标配, 直接用它内置的

backbone依赖underscore, 但是我不依赖backbone
bitsmix
2012-08-30 23:52:53 +08:00
t.js 也不错。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/33398

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX