在开发WEB前端页面时,经常会根据动态的数据加载一些HTML控件,如果把这些HTML代码全写入JS中,根据不同的数据显示的控件也不一样,操作起来会显得比较繁琐,而且极不利于代码的维护,怎么办呢?现在就是我要说的,使用模板方法,直接把数据往里面套就好了。废话不多说,以示例来说明。
先写个非常重要的JS方法,此方法就是用来填充格式数据的。(看不懂也没关系,会用就行)
Js代码
1 | function formatTemplate(dta, tmpl) { |
接下来就用示例来说明:
例如:从服务器取出一个JSON串,把数据显示在一组HTML控件上,现在我先把HTML代码写下来:
Html代码
1 | <script type=“text/template”> |
大家看到了这段代码,如果全部写JS上确实比较烦,而且大家也发现了,为什么在首尾有<script>
标签,里面有{}括号括住了一些值,为什么这么写呢,别急别急。其实这些{}号中的数据,就是我们要填充的数据的地方。括号中的名称就是存贮值的变量,好,要怎么填呢?
若我们从服务器上取到的JSON如下:
Js代码
1 | { |
我们要填写到地方定义在下面Table中
Html代码
1 | <html> |
哟嚯,搞定,等等,好像表格的列数对不上,是吧,那是因为我没有把模板写完整出来,继续往下看。
现在我来解释为什么把模板代码放在<script></script>
中间,假如,你把模板代码放在某个<div>
中并隐藏起来,那么可能你的代码中会用到$(‘input[type=”text”]’)查找控件时,不好意思,就会把模板中的也统计进去了,这个并不是你想要的。所以我用<script>
,这么做还有一个好处,就是不会被当成HTML来执行显示出来, 但我们也得保证不能当成js来执行,所以加了个type=”text/template”,没有这个类型的,自己明白就好了。
另外,像o.mid的数值只会填充到{mid}这个里,不会填充到别的地方去,而且{mid}可以存在多个,一并全部替换成实际数值了。
接下来的一个问题就是,我取到的数据可能并不是我要给用户显示的,那么就需要变通一下了
Js代码
1 | var html = $(‘script[type=”text/template”]’).html(); |
完整的HTML模板如下:
1 | <script type=“text/template”> |
其实想通了还是挺简单的,当然formatTemplate函数中的第一个参数必须要求是像struct的对象,直接一点就是这样一个数据包: { “A”: “a”, “B”: “b”, “C”:”c” } 。懂了吧伙计们,不懂就慢慢看吧,嘿嘿!
附: 格式化时间函数:
1 | function getFormatDate(xdate, format) { |
在开发WEB前端页面时,经常会根据动态的数据加载一些HTML控件,如果把这些HTML代码全写入JS中,根据不同的数据显示的控件也不一样,操作起来会显得比较繁琐,而且极不利于代码的维护,怎么办呢?现在就是我要说的,使用模板方法,直接把数据往里面套就好了。废话不多说,以示例来说明。
先写个非常重要的JS方法,此方法就是用来填充格式数据的。(看不懂也没关系,会用就行)
Js代码
1 | function formatTemplate(dta, tmpl) { |
接下来就用示例来说明:
例如:从服务器取出一个JSON串,把数据显示在一组HTML控件上,现在我先把HTML代码写下来:
1 | <script type=“text/template”> |
大家看到了这段代码,如果全部写JS上确实比较烦,而且大家也发现了,为什么在首尾有<script>
标签,里面有{}括号括住了一些值,为什么这么写呢,别急别急。其实这些{}号中的数据,就是我们要填充的数据的地方。括号中的名称就是存贮值的变量,好,要怎么填呢?
若我们从服务器上取到的JSON如下:
1 | { |
我们要填写到地方定义在下面Table中
1 | <html> |
好了准备工作做好了,重点的来了,别看走眼了:
1 | $.ajax({ |
哟嚯,搞定,等等,好像表格的列数对不上,是吧,那是因为我没有把模板写完整出来,继续往下看。
现在我来解释为什么把模板代码放在<script></script>
中间,假如,你把模板代码放在某个<div>
中并隐藏起来,那么可能你的代码中会用到$(‘input[type=”text”]’)查找控件时,不好意思,就会把模板中的也统计进去了,这个并不是你想要的。所以我用<script>
,这么做还有一个好处,就是不会被当成HTML来执行显示出来,但我们也得保证不能当成js来执行,所以加了个type=”text/template”,没有这个类型的,自己明白就好了。
另外,像o.mid
的数值只会填充到{mid}这个里,不会填充到别的地方去,而且{mid}可以存在多个,一并全部替换成实际数值了。
接下来的一个问题就是,我取到的数据可能并不是我要给用户显示的,那么就需要变通一下了
1 | var html = $(‘script[type=”text/template”]’).html(); |
完整的HTML模板如下:
1 | <script type=“text/template”> |
其实想通了还是挺简单的,当然formatTemplate函数中的第一个参数必须要求是像struct的对象,直接一点就是这样一个数据包: { “A”: “a”, “B”: “b”, “C”:”c” } 。懂了吧伙计们,不懂就慢慢看吧,嘿嘿!
附: 格式化时间函数:
1 | function getFormatDate(xdate, format) { |