`
fkpwolf
  • 浏览: 49925 次
  • 性别: Icon_minigender_1
  • 来自: 爱你就是认识我自己
文章分类
社区版块
存档分类
最新评论

关于json template一点思考

阅读更多

如果ajax调用从server返回的是json,那么client如何把json render成html呢?

 

我看到一个叫json-template的js库,比如如下的代码,有点像xslt转换xml

 

{# This is a comment and will be removed from the output.}

{.section songs}
  <h2>Songs in '{playlist-name}'</h2>

  <table width="100%">
  {.repeated section @}
    <tr>
      <td><a href="{url-base|htmltag}{url|htmltag}">Play</a>
      <td><i>{title}</i></td>
      <td>{artist}</td>
    </tr>
  {.end}
  </table>
{.or}
  <p><em>(No page content matches)</em></p>
{.end}

不过这样感觉有点把事情复杂化了,我本意只是想把json转换成html。

 

难道应该从server端直接传回html么?

 

从server端直接传回HTML有个缺点,就是html只是用来显示(view)的,如果我们用html来传递所有的数据,势必有些数据要放到hidden的element中,这样html看起来很混乱。如果不放到hidden input中,也可以放到element attribute或者class中,少量的数据可以,多了就显得有点怪异了,影响了HTML语义semantical,这里有解释。HTML5中有些改进,不过我看也不是很优雅的解决方法。

 

放到json中的话作为一个统一的model来交给ajax(control)来处理。

 

感觉我需要的是一个mvc的javascript框架,我知道dojo中也有templete的东东,不过我不大熟悉,不知道是否解决了这个问题。(这里有篇如何创建widget的文章,感觉正是我需要的)。dojo包装的比较深,我不大明白其底层是用何种机制来保存这些数据的。其实数据保存在那里无关紧要(在firebug中可以看到,还是保存在DOM中),更重要的是要建立对象(widget)和标准HTML的bind关系。

 

Using template in Django ? 这篇文章也同意我的观点,他用到了一个叫jBind的emplate engine

google也有个tool叫closure-templates,跟一般的模板不同的是它可以把模板文件编译成javascript,这样性能就更好些。

 

关于dojo的东西后续讨论我放到了我的博客这里:

从“在HTML中嵌入数 据”到Dojo的组件模型

分享到:
评论
20 楼 fkpwolf 2010-03-08  
大家使用模板时遇到翻译的问题没有,google的closure templates刚好有这个功能,参考这里:http://code.google.com/intl/zh-CN/closure/templates/docs/translation.html

它是使用了一个叫XLIFF的一种标准格式来保存翻译文本,感觉还是很专业的。

如果这些模板在jsp中保持,用类似<%=t "name"%>来处理当然更容易,但是编译模板然后生成js的方法对效率会更好点,因为js可以缓存
19 楼 achun 2010-03-08  
我也推荐一个
俺写的前台模板 jCT 看专题吧
http://achun.iteye.com/category/33268
18 楼 rainchen 2010-03-07  
或者可以参考Firefox的模板语法特性(或者利用这个思路来置换模板的内容):
http://www.w3schools.com/e4x/tryit.asp?filename=trye4x_demo
17 楼 rainchen 2010-03-07  
楼主可以看看这个模板:http://github.com/edspencer/jaml
Templating
Usually we want to inject data into templates – let’s see how to do that:
Jaml.register('product', function(product) {
  div({cls: 'product'},
    h1(product.title),

    p(product.description),

    img({src: product.thumbUrl}),
    a({href: product.imageUrl}, 'View larger image'),

    form(
      label({for: 'quantity'}, "Quantity"),
      input({type: 'text', name: 'quantity', id: 'quantity', value: 1}),

      input({type: 'submit', value: 'Add to Cart'})
    )
  );
});

And now to render it:
//this is the product we will be rendering
var bsg = {
  title      : 'Battlestar Galactica DVDs',
  thumbUrl   : 'thumbnail.png',
  imageUrl   : 'image.png',
  description: 'Best. Show. Evar.'
};

Jaml.render('product', bsg);

Which gives us:
<div class="product">
  <h1>Battlestar Galactica DVDs</h1>
  <p>Best. Show. Evar.</p>
  <img src="thumbnail.png" />
  <a href="image.png">View larger image</a>
  <form>
    <label for="quantity">Quantity</label>
    <input type="text" name="quantity" id="quantity" value="1"></input>
    <input type="submit" value="Add to Cart"></input>
  </form>
</div>
16 楼 fkpwolf 2010-03-07  
akandfxs 写道
hehe,我的理解,js相关的东西比如数据和模板,不一定是js编出来的,可以通过java,.net等生成。js这个东西其实模糊了前后台的界限的。其实你调用一个js函数,完全不必理会它是前段计算还是后端计算。

是的。我在试用模板时,发现模板中的数据其实很多要用代码产生出来,最常见的比如翻译文字。
所以这里有点像模板(json)的模板(jsp)
15 楼 akandfxs 2010-03-06  
hehe,我的理解,js相关的东西比如数据和模板,不一定是js编出来的,可以通过java,.net等生成。js这个东西其实模糊了前后台的界限的。其实你调用一个js函数,完全不必理会它是前段计算还是后端计算。
14 楼 fkpwolf 2010-03-05  
jindw 写道
fkpwolf 写道
jindw 写道
fkpwolf 写道
jindw 写道
前端模板必须借助后端模板这个平台才能发展起来。
对前端模板感兴趣的同学可以试试这个:

http://lite.googlecode.com


server端也要模板么?难道生成json也要模板?


无语了,可怜的纯前端工程师。

我这样认为:既然json已经在client端用模板来生成html,server端难道还要用模板来render json?如果后端模板指jsp, rails之类,那应该跟前端模板关系不大,它只管生成json。

错误之处请赐教。


定势思维害死人。
前后端的分工并不应该局限在是否在浏览器上运行。
而应该更多关注某种逻辑是否与展现相关。

这,不是很明白,我就不揣摩圣衣了。
13 楼 jindw 2010-03-05  
fkpwolf 写道
jindw 写道
fkpwolf 写道
jindw 写道
前端模板必须借助后端模板这个平台才能发展起来。
对前端模板感兴趣的同学可以试试这个:

http://lite.googlecode.com


server端也要模板么?难道生成json也要模板?


无语了,可怜的纯前端工程师。

我这样认为:既然json已经在client端用模板来生成html,server端难道还要用模板来render json?如果后端模板指jsp, rails之类,那应该跟前端模板关系不大,它只管生成json。

错误之处请赐教。


定势思维害死人。
前后端的分工并不应该局限在是否在浏览器上运行。
而应该更多关注某种逻辑是否与展现相关。
12 楼 fkpwolf 2010-03-05  
jindw 写道
fkpwolf 写道
jindw 写道
前端模板必须借助后端模板这个平台才能发展起来。
对前端模板感兴趣的同学可以试试这个:

http://lite.googlecode.com


server端也要模板么?难道生成json也要模板?


无语了,可怜的纯前端工程师。

我这样认为:既然json已经在client端用模板来生成html,server端难道还要用模板来render json?如果后端模板指jsp, rails之类,那应该跟前端模板关系不大,它只管生成json。

错误之处请赐教。
11 楼 jindw 2010-03-04  
fkpwolf 写道
jindw 写道
前端模板必须借助后端模板这个平台才能发展起来。
对前端模板感兴趣的同学可以试试这个:

http://lite.googlecode.com


server端也要模板么?难道生成json也要模板?


无语了,可怜的纯前端工程师。
10 楼 weiqiang.yang 2010-03-04  
google的jst也不错,项目在用~~
9 楼 fkpwolf 2010-03-04  
jindw 写道
前端模板必须借助后端模板这个平台才能发展起来。
对前端模板感兴趣的同学可以试试这个:

http://lite.googlecode.com


server端也要模板么?难道生成json也要模板?
8 楼 upup1000 2010-03-04  
Ext的XTemplate,功能也不弱
7 楼 upup1000 2010-03-04  
var tpl = new Ext.XTemplate(
    '<p>Name: {name}</p>',
    '<p>Kids: ',
    '<tpl for="kids">',
        '<tpl if="this.isGirl(name)">',
            '<p>Girl: {name} - {age}</p>',
        '</tpl>',
        '<tpl if="this.isGirl(name) == false">',
            '<p>Boy: {name} - {age}</p>',
        '</tpl>',
        '<tpl if="this.isBaby(age)">',
            '<p>{name} is a baby!</p>',
        '</tpl>',
    '</tpl></p>', {
     isGirl: function(name){
         return name == 'Sara Grace';
     },
     isBaby: function(age){
        return age < 1;
     }
});
tpl.overwrite(panel.body, data);
6 楼 jindw 2010-03-03  
前端模板必须借助后端模板这个平台才能发展起来。
对前端模板感兴趣的同学可以试试这个:

http://lite.googlecode.com
5 楼 faiinlove 2010-03-03  
fkpwolf 写道
多谢提醒。不过现在我发现使用templete后,json还是没有bind到html,要bind还得手工做。比如取html里面的值,根原来的json就脱离了。感觉dojo这方面还是很强的,以widget或者component方式来处理html,比较单薄的templete更容易处理。

Adobe的Spry框架就是bind到html的·· 而且支持复杂的bind。而且datastore刷新后html会跟着刷新,是个不错的东西! 而且支持多种datastore格式,包括json,xml,html! 而且2行代码就可以出来数据了。而且支持主从数据。
现在想来,它的功能真多啊。而且DW Cs3 就自带了!
4 楼 kuchaguangjie 2010-03-03  
法一,返回 html/jsp 片段
法二,返回json后,自己用 js 操作之
法三,用 json 库,比如 json-taglib,和你说的 json-template
3 楼 fkpwolf 2010-03-03  
多谢提醒。不过现在我发现使用templete后,json还是没有bind到html,要bind还得手工做。比如取html里面的值,根原来的json就脱离了。感觉dojo这方面还是很强的,以widget或者component方式来处理html,比较单薄的templete更容易处理。
2 楼 faiinlove 2010-03-03  
对于json数据刷新到模版,我建议楼主参考一下adobe的spry框架,完全符合楼主的需求。而且不大的一个框架。完全可以和其他js库混用。。 
1 楼 lxy19791111 2010-03-03  
楼主可以看看这个jTemplates,这是一个jQuery模板插件,功能非常将大,就像客户端的FreeMarker,我用过感觉不错,网址:http://jtemplates.tpython.com/

相关推荐

    json template最新源代码

    json template最新源代码json template最新源代码json template最新源代码json template最新源代码json template最新源代码json template最新源代码json template最新源代码json template最新源代码json template...

    运用Jquery插件Json2Template写的简单项目

    在本文中,我们将深入探讨如何使用Jquery插件Json2Template进行项目开发。Json2Template是一款基于jQuery的库,它允许开发者将JSON数据动态渲染为HTML模板,极大地提高了前端界面的数据展示效率。在学习和应用这个...

    json-template:一个json编辑器

    JSON TEMPLATE 可视化配置工具 为什么做JSON TEMPLATE 前端组件越来越多,组件的配置一般都是JSON格式的。有些面向用户展示的组件,很多时候运营人员是要修改配置的的,但是把代码暴漏给运营人员是相当不靠谱的,...

    Kugar.Core.Web.JsonTemplate:WebApi格式化Json的类库

    《Kugar.Core.Web.JsonTemplate:WebApi JSON格式化利器》 在现代Web开发中,API接口扮演着至关重要的角色,而JSON作为数据交换的主要格式,其格式化的重要性不言而喻。Kugar.Core.Web.JsonTemplate是一款针对Web...

    logstash-template模板:logstash.json

    在Logstash中,模板(Template)扮演着重要的角色,它定义了Elasticsearch如何存储和索引由Logstash发送的数据。`logstash.json` 文件就是这样一个预定义的模板,用于规定数据的结构和字段类型,确保数据在导入时...

    wazuh-elastic7-template-alerts.json

    wazuh-elastic7-template-alerts.json,wazuh的ES模块导入

    Json+NVelocity模板引擎C#入门示例,比较全面

    在IT领域,Json和NVelocity模板引擎是两个重要的技术组件,尤其在C#开发中有着广泛的应用。Json是一种轻量级的数据交换格式,易于人阅读和编写,同时也易于机器解析和生成。NVelocity则是一个开源的Java模板引擎,...

    json转换jsonschema

    而JSON Schema则是一个JSON格式的规范,用于定义JSON数据的结构和限制,类似于XML Schema,它为JSON数据提供了验证规则,确保数据的准确性和一致性。 在JavaScript开发中,有时我们需要将JSON对象转换为JSON Schema...

    MFC使用json11解析JSON

    json11::Json jsonObject = json11::Json::parse(jsonString); if (jsonObject.is_object()) { // 处理解析成功的对象 } else { // 处理解析错误 } ``` 一旦你有了JSON对象,可以访问其成员或进行修改。例如,...

    apache-template.json

    apache-template.json

    SampleJson2Template josn转化成hmtl页面 下载

    标题 "SampleJson2Template josn转化成hmtl页面 下载" 暗示了这是一个关于将JSON数据转换为HTML页面的项目。JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,常用于前后端数据传输。而将JSON转换为...

    最好用的c++json库 nlohmann json源代码

    最好用的c++json库 nlohmann json源代码最好用的c++json库 nlohmann json源代码最好用的c++json库 nlohmann json源代码最好用的c++json库 nlohmann json源代码最好用的c++json库 nlohmann json源代码最好用的c++json...

    java json api,json api

    Java JSON API是Java平台上的库,提供了处理JSON的能力,包括解析JSON字符串、生成JSON对象以及进行JSON与Java对象之间的转换。 在Java中,有多种实现JSON API的库,如Jackson、Gson、org.json和json-lib等。本篇...

    关于JSON的知识------JSON 只是简介

    这是一个静态页面,里面介绍了关于JSON的知识,如果需要得到jsp,asp,js,java,c++等等各种语言里JSON的知识和运用工具,可以用页面下方的链接去找。

    template.json

    template.json

    JSON net.sf.json jar包

    JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,被广泛用于Web服务和应用程序之间的数据传输。它易于人阅读和编写,同时也易于机器解析和生成。`net.sf.json`是开源项目Apache软件基金会下的一个...

    json3.js 【JS / JavaScript 中解析JSON的js包,JSON官方的JSON解析包】

    json3.js 【JS / JavaScript 中解析JSON的js包,JSON官方的JSON解析包】。JavaScript中解析JSON的js包,页面中引入json3.js,即可使用。 使用方法:JSON.parse(str), JSON.stringify(obj) 更多详情请参考博文: ...

    json-c 一个用于c语言的json解析库,很强大

    在这个例子中,我们首先使用`json_tokener_parse`解析JSON字符串,然后通过`json_object_get_string`和`json_object_get_int`获取JSON对象中的数据,最后使用`json_object_put`释放内存。这就是`json-c`库基本的使用...

    JSON JSON .zip

    - JSON不支持注释,因此在编写时需要注意这一点。 - 对象内的键值对和数组中的元素都以逗号分隔,但最后一个元素后面不能有逗号。 在实际应用中,JSON常用于API接口的数据交换,例如,Web服务提供JSON格式的响应...

    Linux JSON 常用解析命令总结

    - `-e &lt;template&gt;`:设置要过滤的键。 - `-t`:当与`-e`选项一起使用时,可以指定多个过滤条件。 - `-q`:禁止输出任何错误信息。 **示例**: 假设有一个名为`json.txt`的JSON文件,内容如下: ```json { "name...

Global site tag (gtag.js) - Google Analytics