位置: 编程技术 - 正文

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怎么用)

  • 股东利润分配怎么做账
  • 税务局开专票作废重开流程
  • 财会英语汇总:税收术语?
  • 累计折旧贷方余额表示
  • 9个点的发票跟6个点区别
  • 附加税预缴分录
  • 销项税现金流量指定
  • 支付资金占用费怎么记账进项税
  • 主营业务成本计算公式是什么
  • 给非企业员工佣金怎么交税
  • 付给其他公司的服务费怎么记账
  • 银行利息收入要开票吗
  • 注册资金印花税是资金账簿吗
  • 医疗器械 税点
  • 垫付按揭保证金怎么做账
  • 支付教育培训费
  • 房地产企业收到房款账务处理
  • 进出口免抵退税操作
  • 零申报逾期未申报怎么补报
  • windows10如何切屏
  • 设备计提折旧的方法
  • 仓库折旧费
  • 无形资产资本化和费用化的区别
  • php环境配置教程Apace
  • 借条未写还款期限,最长保护期是多久
  • 已删除好友的聊天记录
  • linux mib
  • win10待机后无法输入密码
  • php图片加文字水印
  • 包装物适用的税率是多少
  • php判断字符串是否合法日期
  • 最贵的手机号码值多少钱
  • 不得领购使用增值税专用发票
  • 将自产的应税消费品用于连续生产应税消费品
  • win10系统安装配置
  • ts中如何定义一个数组
  • js倒计时函数
  • 帝国cms app
  • 代理记账费用计入什么二级科目
  • 诉讼费发票丢失可以补开吗
  • 进口关税账务处理办法
  • python项目开发案例集锦pdf百度网盘
  • 企业应纳税所得额的计算应遵循权责发生制原则
  • 万元发票和千元发票
  • 企业成立刻章流程
  • 残疾人保障金所属期怎么填
  • mysql8绿色版安装
  • 资产负债表的固定资产怎么算出来的
  • 企业与股东之间的关系,也是企业与投资者之间的关系
  • 委托收款的业务场景有哪些
  • 稀释股权违法吗
  • 设计费要计入固定成本吗
  • 单位的收入是刷卡怎么做账?
  • 原材料运费如何入账
  • 广告赞助的形式
  • 旅游费用如何记账科目
  • mysql在指定字段前添加
  • aesm_service.exe是什么
  • mac系统自带的杀毒软件
  • win+tab键
  • 升级win10后
  • Metaio in Unity3d 教程--- 一. 搭建环境,运行官方案例
  • 所见即所得出自哪里
  • Jquery ajax基础教程
  • 安卓十游戏怎么玩
  • shell脚本监控日志输出
  • cocos creator rpg
  • 彻底弄懂js中的this指向
  • Node.js中的construct
  • 大家看的是什么
  • python搜索引擎网络爬虫
  • unity调用c++动态库
  • vue怎么做兼容
  • html焦点图
  • unity控制三维模型
  • Python的for和in
  • 贸易公司的税率多少
  • 五险一金不满一年可以领失业金吗
  • 关税由谁来承担
  • 收缴和缴纳的区别
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设