我的经验是,直接把 HTML 单独写到一个浏览器能访问到的文件里,比如 template/foo.html。然后 JS 里发一个同步 XHR 请求去读这个文件,例如:
var html = Template.load('/template/foo.html')
var target = document.getElementById('xxx')
target.innerHTML = html
Template 是一个工具类,负责发送同步 XHR 请求并返回结果。
这样在开发的时候,模板文件和 JS 代码分离,非常好维护。
当然这样做的话,上线的时候总发 XHR 请求也不是办法。所以在打包 JS 之前,我一般会通过脚本把所有的 Template.load('.*') 提取出来,替换成对应 HTML 的内容。这样在开发时非常方便,上线时也没有性能问题。
比如上面的代码被打包工具跑一下就变成了:
var html = "\n...\n"// 引号里是 /template/foo.html 对引号、换行做了转义之后的内容,由工具自动生成
var target = document.getElementById('xxx')
target.innerHTML = html
你可以新建一个jsp页面,将html中<html></html>标签中的内容替换jsp页面中<html></html>内容即可。但注意jsp页面中的第一行:
<%@ page language="java" import="java.util.*" pageEncoding="ISO-8859-1"%>改为:
<%@ page language="java" import="java.util.*" pageEncoding="GBK"%>
这行意思是你用到了包和页面中显示的是中文。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)