位置: 编程技术 - 正文

nodejs中art-template模板语法的引入及冲突解决方案

编辑:rootadmin

推荐整理分享nodejs中art-template模板语法的引入及冲突解决方案,希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:,内容如对您有帮助,希望把文章链接给更多的朋友!

使用Webstorm创建nodejs express应用时,默认使用的是jade或者ejs模板,对于不习惯这两种模板语法的人来说确实不是很方便。没关系,这里我们使用art-template模板引擎,使用后可以直接使用html模板:

1、安装art-template

2、修改app.js文件,添加如下代码:

3、然后直接创建html页面,js路由便可以直接访问了

4、首先在app.js中添加如下路由拦截:

然后是index.js文件:

这里我跳转到index2页面(配置好了art-template模板引擎后,视图层默认文件后缀即为html),index2.html页面如下:

运行应用,浏览器输出如下:

nodejs中art-template模板语法冲突解决方案

art-template的github地址: {{ }} 和尖括号语法 <%= %>

本篇文章主要介绍一下在nodejs中,art-template如何解决模板引擎语法冲突

nodejs中art-template模板语法的引入及冲突解决方案

1.1-模板引擎语法冲突的场景

1.如果一个html文件中,既存在客户端渲染,也存在服务端渲染的话,那么这两种渲染的模板引擎语法不能一致,否则在加载时服务端渲染就已经将客户端的模板也一并渲染了

2.一般遇到这种情况,例如一个html文件中既有服务端渲染又有客户端渲染的情况下,服务端的模板引擎我们使用 {{ }} 语法,客户端渲染我们使用 <%= %>

3.在nodejs中,我们使用npm来安装art-template之后: npm install art-template ,默认情况下art-template是同时支持浏览器端与服务端的,并且他们之间的导入文件是不同的

1.2-配置art-template服务端模板语法

1.如果是服务端,我们使用 require('art-template') 来导入,此时加载的是 index.js ,这里的index.js值得是根目录下的index.js,这是nodejs模块加载机制的入口,它的内部非常简单,就是做了一个文件导入操作。

服务端的art-template的模板语法源代码在 art-template 的 lib 文件夹下的 compile文件夹 对应的 adapter 中,两种模板语法分别对应的文件是 rule.art.js简洁语法 , rule.native.js原生语法 ,如下图

2.如果是客户端,我们则不能使用服务端的模板语法文件,这是因为nodejs遵循的是commonjs的规范,所有的文件API都是以模块的形式导出,在 art-template 文件夹, lib -> compile 文件夹中有一个专用于客户端的模板语法文件 template-web.js ,这是一个压缩的js包

3.浏览器的模板语法默认支持两种语法,简洁和原生,这个无法修改。但是我们可以通过修改服务端的源代码,使服务端只支持一种模板语法 {{ }} ,这样的话我们在客户端使用 <%= %> 语法,服务器就无法渲染了

经过本人对 art-template 源码的分析,发现 art-template 的服务端两种模板语法是在 compile 文件下有一个 default.js 文件中导入的,所以我们只需要稍微修改一下源码即可

默认是一个数组来配置模板语法,[nativeRule, artRule]同时支持两种模板语法,我们去掉nativeRule即可,此时服务端只支持 {{}} 语法,该代码修改不会对客户端造成影响

大功告成,此时服务端与客户端的模板语法就不会冲突了

标签: nodejs中art-template模板语法的引入及冲突解决方案

本文链接地址:https://www.jiuchutong.com/biancheng/368547.html 转载请保留说明!

上一篇:Node.js实现发送邮件功能(nodejs发送http请求)

下一篇:mongoose设置unique不生效问题的解决及如何移除unique的限制(mongoose怎么用)

  • 附加税减半征收的条件
  • 贷款利息收入如何开票
  • 库存商品转为固定资产说明
  • 哪些科目月底需要结转
  • 企业付的快递费是扣增值税还是进入费用扣除
  • 营改增前土地增值税的计算方法
  • 进口环节关税税率
  • 取得特许权使用费收入增值税税率
  • 护栏发票税点
  • 买车交税怎么算价格
  • 兼职取酬案例剖析
  • 单位不发工资怎么解决要什么证据
  • 固定资产原值变更当月计提折旧
  • 提高并购成本
  • 资金筹集业务核算实训心得体会
  • 公司注销了之后银行账户还能用吗
  • 企业的应收账款周转率越大,说明发生坏账
  • 员工福利费用会计怎么做
  • 资产负债表没有实收资本正常吗
  • 累计折旧的计提和处理的分录
  • 个人开农产品发票流程
  • window休眠
  • 税盘减免税款的会计分录
  • 输入字母和数字 小学信息技术课
  • mac 如何u盘启动
  • Remoterm.exe - Remoterm是什么进程 有什么用
  • 附有退货权商品是什么
  • 营改增的会计分录
  • 个人减免税政策6条
  • 老板垫付的员工怎么入账
  • 红字发票开具后蓝字发票开具时限的问题
  • laravel实现登录注册
  • 数字图像处理-应用篇
  • php开发接口
  • Node 下 Http Streaming 的跨浏览器实现
  • 附清单格式
  • 进项税加计抵减是什么意思
  • 织梦标签理解
  • 餐饮发票数量单价都填0可以用吗
  • 一般纳税人差额纳税
  • sql server 2008使用教程
  • 成本票和进项票举例说明
  • mysql中的索引有
  • mysql创建存储过程sql语句
  • 研发费用加计扣除是什么意思啊
  • 销售商品发生的应收账款入账价值包括
  • 电子凭证用不了
  • 增值税代扣代缴范围
  • 出口转内销补交进口增值税时间
  • 账户分类的作用是什么
  • 公司现金支票取现要缴税吗
  • 权益类会计科目有哪些科目
  • 建筑公司的会计好做吗
  • MySQL 5.7双主同步部分表的实现过程详解
  • ubuntu配置yum
  • fedora 10
  • wpl是什么文件
  • win7系统升级到win10后,还能还原回来吗
  • windows xp windows
  • Win7旗舰版系统文件名称
  • windows7可以打开多个窗口
  • rhel7配置ip地址
  • Centos 6.5 64位双网卡绑定教程
  • linux临时修改编码
  • 后缀是nb是什么程序
  • 怎样查看windows10版本
  • win10输入法图标消失
  • Facebook Open Platform编译FAQ
  • 四步制作的花
  • quick-cocos2d-x如何在mac下编译安卓版本
  • call to OpenGL ES API with no current context (logged once per thread)
  • python 正则 \s
  • gridlayout动态添加view
  • python绘图题
  • python+Django+apache的配置方法详解
  • 小规模纳税人网上申报
  • 威科先行法律信息库价格
  • 广州酒家月饼抽奖公告最新
  • 杭州国家税务局陈英泽
  • 鸿蒙2.0哪个版本续航好
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设