基于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 相关文章推荐
走出JavaScript初学困境—js初学
Dec 29 Javascript
一个js写的日历(代码部分网摘)
Sep 20 Javascript
javascript用户注册提示效果的简单实例
Aug 17 Javascript
js实现checkbox全选和反选示例
May 01 Javascript
jQuery操作DOM_动力节点Java学院整理
Jul 04 jQuery
基于IView中on-change属性的使用详解
Mar 15 Javascript
vuex进阶知识点巩固
May 20 Javascript
微信小程序实现分享到朋友圈功能
Jul 19 Javascript
JavaScript创建对象方式总结【工厂模式、构造函数模式、原型模式等】
Dec 19 Javascript
[jQuery] 事件和动画详解
Mar 05 jQuery
详解基于React.js和Node.js的SSR实现方案
Mar 21 Javascript
vue中keep-alive,include的缓存问题
Nov 26 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
PHP常用编译参数中文说明
2014/09/27 PHP
PHP实现添加购物车功能
2017/03/06 PHP
Laravel5.0+框架邮件发送功能实现方法图文与实例详解
2019/04/23 PHP
js 编写规范
2010/03/03 Javascript
js面向对象设计用{}好还是function(){}好(构造函数)
2011/10/23 Javascript
datagrid框架的删除添加与修改
2013/04/08 Javascript
JavaScript检查某个function是否是原生代码的方法
2014/08/20 Javascript
jquery实现简单实用的弹出层效果代码
2015/10/15 Javascript
node.js学习之交互式解释器REPL详解
2016/12/08 Javascript
微信小程序 数据封装,参数传值等经验分享
2017/01/09 Javascript
如何将 jQuery 从你的 Bootstrap 项目中移除(取而代之使用Vue.js)
2017/07/17 jQuery
javascript使用正则表达式实现注册登入校验
2020/09/23 Javascript
vue router-link 默认a标签去除下划线的实现
2020/11/06 Javascript
跟老齐学Python之Import 模块
2014/10/13 Python
深入讲解Java编程中类的生命周期
2016/02/05 Python
Django项目中包含多个应用时对url的配置方法
2018/05/30 Python
python实现的Iou与Giou代码
2020/01/18 Python
Python定时器线程池原理详解
2020/02/26 Python
简单了解python调用其他脚本方法实例
2020/03/26 Python
python如何调用字典的key
2020/05/25 Python
python是怎么被发明的
2020/06/15 Python
vscode调试django项目的方法
2020/08/06 Python
python 实现波浪滤镜特效
2020/12/02 Python
CSS3关于z-index不生效问题的解决
2020/02/19 HTML / CSS
HTML5图片预览实例分享
2014/06/04 HTML / CSS
新加坡领先的时尚生活方式零售品牌:CHARLES & KEITH
2018/01/16 全球购物
求职自荐书范文
2013/12/04 职场文书
公司接待方案
2014/03/08 职场文书
教师评语大全
2014/04/28 职场文书
房地产公司见习自我鉴定
2014/04/28 职场文书
大型会议策划方案
2014/05/17 职场文书
2014年监理个人工作总结
2014/12/11 职场文书
学校食堂食品安全承诺书
2015/04/29 职场文书
关于做家务的心得体会
2016/01/23 职场文书
Redis安装启动及常见数据类型
2021/04/14 Redis
MySQL创建管理RANGE分区
2022/04/13 MySQL