基于react后端渲染模板引擎noox发布使用


Posted in Javascript onJanuary 11, 2018

React 组件化思想受到越来越多开发者的关注,组件化思想帮助开发者将页面解耦成一个一个组件,代码更加模块化, 更易扩展。而目前流行的后端模板引擎如 ejs, swig, jade, art 共同的问题是:

  1. 需要学习各类模板引擎定义的语法,如 {{if}}, {{loop}}
  2. 对组件化支持不够强,实现复杂,不易用

针对以上痛点,笔者基于 React 造出了 noox 这样一个工具,专注于后端模板的解析,让模板解析更加简单,易用。

使用方法

安装

npm install noox

简单的 demo

模板代码

首先创建组件目录和增加模板文件

mkdir components && cd components
vi Head.jsx

Head.jsx 内容如下:

<head>
 <title>{title}</title>
 <meta name="description" content={props.description} />
 <link rel="stylesheet" href="./css/style.css" rel="external nofollow" rel="external nofollow" />
</head>

Node.js Code

const noox = require('noox');
const nx = new noox(path.resolve(__dirname, './components'), {title: 'noox'});
let output = nx.render('Head', {description: 'hello, noox.'})

输出

<head>
 <title>noox</title>
 <meta name="description" content="hello, noox." />
 <link rel="stylesheet" href="./css/style.css" rel="external nofollow" rel="external nofollow" />
</head>

原理

Noox 在 React 的 Jsx 的基础上,简化了组件引用和创建,假设创建一个目录结构如下:

components/
 Header.jsx
 Body.jsx
 Layout.jsx

运行如下 nodejs 的代码:

nx = new noox(path.resolve(__dirname, './components'))

将会创建三个组件:

  1. Header
  2. Body
  3. Layout

然后通过 nx.render 渲染

nx.render('Body', props)

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jQuery 前的按键判断代码
Mar 19 Javascript
HTML5附件拖拽上传drop &amp; google.gears实现代码
Apr 28 Javascript
12款经典的白富美型—jquery图片轮播插件—前端开发必备
Jan 08 Javascript
YUI模块开发原理详解
Nov 18 Javascript
JavaScript字符串对象replace方法实例(用于字符串替换或正则替换)
Oct 16 Javascript
node.js中的buffer.Buffer.byteLength方法使用说明
Dec 10 Javascript
javascript使用for循环批量注册的事件不能正确获取索引值的解决方法
Dec 20 Javascript
移动设备web开发首选框架:zeptojs介绍
Jan 29 Javascript
基于Bootstrap实现下拉菜单项和表单导航条(两个菜单项,一个下拉菜单和登录表单导航条)
Jul 22 Javascript
jQuery常见的选择器及用法介绍
Dec 20 Javascript
Vue引用第三方datepicker插件无法监听datepicker输入框的值的解决
Jan 27 Javascript
vue动态渲染svg、添加点击事件的实现
Mar 13 Javascript
Router解决跨模块下的页面跳转示例
Jan 11 #Javascript
vuex 使用文档小结篇
Jan 11 #Javascript
js判断传入时间和当前时间大小实例(超简单)
Jan 11 #Javascript
js点击时关闭该范围下拉菜单之外的菜单方法
Jan 11 #Javascript
纯js代码生成可搜索选择下拉列表的实例
Jan 11 #Javascript
web前端vue之vuex单独一文件使用方式实例详解
Jan 11 #Javascript
vue-cli webpack 引入jquery的方法
Jan 10 #jQuery
You might like
通过文字传递创建的图形按钮
2006/10/09 PHP
php 生成饼图 三维饼图
2009/09/28 PHP
php 引用(&amp;)详解
2009/11/20 PHP
php IP转换整形(ip2long)的详解
2013/06/06 PHP
Session的工作机制详解和安全性问题(PHP实例讲解)
2014/04/10 PHP
PHP实现的DES加密解密封装类完整实例
2017/04/29 PHP
PHP基于递归实现的约瑟夫环算法示例
2017/08/27 PHP
js正文内容高亮效果的实现方法
2013/06/30 Javascript
javaScript面向对象继承方法经典实现
2013/08/20 Javascript
iframe窗口高度自适应的又一个巧妙实现思路
2014/04/04 Javascript
BootStrap Table 分页后重新搜索问题的解决办法
2016/08/08 Javascript
JS实现的相册图片左右滚动完整实例
2016/11/23 Javascript
bootstrap table表格使用方法详解
2017/04/26 Javascript
浅谈ECMAScript6新特性之let、const
2017/08/02 Javascript
layui之select的option叠加问题的解决方法
2018/03/08 Javascript
MVVM框架下实现分页功能示例
2018/06/14 Javascript
CSS3 动画卡顿性能优化的完美解决方案
2018/09/20 Javascript
vue拖拽排序插件vuedraggable使用方法详解
2020/08/21 Javascript
javascript 数组(list)添加/删除的实现
2020/12/17 Javascript
Python(Django)项目与Apache的管理交互的方法
2018/05/16 Python
python tkinter库实现气泡屏保和锁屏
2019/07/29 Python
15个Pythonic的代码示例(值得收藏)
2020/10/29 Python
HTML5探秘:用requestAnimationFrame优化Web动画
2018/06/03 HTML / CSS
HTML5之WebGL 3D概述(下)—借助类库开发及框架介绍
2013/01/31 HTML / CSS
智利最大的网上商店:Linio智利
2016/11/24 全球购物
Deux par Deux官方网站:设计师童装
2020/01/03 全球购物
Zalando Lounge瑞士:时尚与生活方式购物俱乐部
2020/03/12 全球购物
年终自我鉴定
2013/10/09 职场文书
小学一年级学生评语
2014/04/22 职场文书
演讲稿的写法
2014/05/19 职场文书
车间安全生产标语
2014/06/06 职场文书
教师师德考核自我评价
2014/09/13 职场文书
珍惜时间的诗歌赏析
2019/08/23 职场文书
话题作文之成长
2019/12/09 职场文书
mysql 联合索引生效的条件及索引失效的条件
2021/11/20 MySQL
Python获取字典中某个key的value
2022/04/13 Python