原生JS进行前后端同构


Posted in Javascript onApril 22, 2018

什么是前后端同构

明确三个概念:「后端渲染」指传统的 ASP、Java 或 PHP 的渲染机制;「前端渲染」指使用 JS 来渲染页面大部分内容,代表是现在流行的 SPA 单页面应用;「同构渲染」指前后端共用 JS,首次渲染时使用 Node.js 来直出 HTML。一般来说同构渲染是介于前后端中的共有部分。

感觉前端的确是折腾,之前还在流行前后端分离,现在怎么又要做前后端同构了?

原因是现在流行的SPA前端单页面应用比较沉重,首次访问需要加载文件较多,第一次加载过慢,用户需要等待前端进行渲染页面。而且不利于SEO及缓存,并且有一定的开发门槛。

前后端同构通过复用模板和JS文件,让一份代码可以同时跑在服务器和浏览器,首次渲染使用nodejs渲染页面,之后使用SPA路由跳转。可以有效减少用户首次访问的等待时间,并且对SEO比较友好,也便于缓存。

项目简介

本前后端同构项目主要分为两个部分,一个是基于koa2的渲染服务器,另一个是基于原生JS和zepto的前端SPA。

项目的特点是不使用vue和react等框架,门槛低,开发速度快,便于上手,比较轻巧,核心的router部分只有一百行左右的代码。适用于页面交互较少,变化不频繁的场景下,可以有效的提升性能和加载速度。

前端部分

前端部分的核心是路由部分,具体实现可以基于history API或是hash,网上有很多实现,这次主要讲下架构
前端部分采用MVC分层结构。

router层做的主要是创建路由示例,调用路由的get方法,给特定页面绑定来自control层的函数。
形式如:

import control from '../control'

//路由的构造函数支持传入渲染函数,路由的全局名称,路由跳转前调用的钩子
router = new Router(render,'ROUTER',beforeFn)

router.get('/page/a', control.pageA')

control层主要做的是加载跟后端共有的渲染模板和渲染数据,渲染出页面后运行页面函数

形式如:

let control = {
 pageA(req,res) {
  //webpack的动态加载,代码分割功能
  import(/* webpackChunkName: "pageA" */'script/pageA').then(module=> {
  // 检测该页面是否已有服务器渲染好,是的话直接运行module.default
  //否则加载模板和数据进行渲染,最后再调用页面函数
  if(this.needRender(module.default)) {
  //加载数据时访问的地址就是当前准备渲染的页面地址,只是加上了json=1的参数
   loadData('pageA').then(data => 
    res.render(xtpl,data,module.default))
  }
 }
}

// 捕捉webpack热更新,让他只进行相当于页面跳转的操作而不是刷新页面
if(module.hot) {
 module.hot.accept(['script/pageA'], () => {
  control[ROUTER.req.currentControl].call(ROUTER,null,ROUTER.res)
 })
}

view层即模板,这里使用的是xtpl模板,在服务器环境和前端环境下都支持渲染页面

页面函数的形式

页面函数要求使用es6的模块写法,配合webpack的按需加载功能

export default () => {
 window.addEventListener('scroll', fn)
//页面函数支持返回一个卸载函数,在页面离开的时候会被调用
//主要用于内存的释放,定时器的清除,事件监听的移除等等
 return function () {
  window.removeEventListener('scroll', fn)
 }
}

后端部分

使用koa2搭建的一个渲染服务器,在收到前端传来的页面请求时,会向API服务器请求数据,并识别页面请求是否带有json=1的参数,如果带有,则为前端路由跳转时的请求,直接返回数据即可,如果没有带json参数,加载跟前端共用的模板,配合数据进行渲染,发送到浏览器。

Javascript 相关文章推荐
jQuery实现复选框全选/取消全选/反选及获得选择的值
Jun 12 Javascript
jquery+css3打造一款ajax分页插件(自写)
Jun 18 Javascript
js封装可使用的构造函数继承用法分析
Jan 28 Javascript
window.setInterval()方法的定义和用法及offsetLeft与style.left的区别
Nov 11 Javascript
js删除局部变量的实现方法
Jun 25 Javascript
js仿微信公众平台打标签功能
Apr 08 Javascript
微信小程序js文件改变参数并在视图上及时更新【推荐】
Jun 11 Javascript
angular6 利用 ngContentOutlet 实现组件位置交换(重排)
Nov 02 Javascript
vue form check 表单验证的实现代码
Dec 09 Javascript
Echarts实现单条折线可拖拽效果
Dec 19 Javascript
javascript设计模式 ? 工厂模式原理与应用实例分析
Apr 09 Javascript
JS实现公告上线滚动效果
Jan 10 Javascript
如何以Angular的姿势打开Font-Awesome详解
Apr 22 #Javascript
vue移动端实现下拉刷新
Apr 22 #Javascript
实例讲解Vue.js中router传参
Apr 22 #Javascript
用Vue写一个分页器的示例代码
Apr 22 #Javascript
vue-cli3.0 特性解读
Apr 22 #Javascript
JS实现的哈夫曼编码示例【原始版与修改版】
Apr 22 #Javascript
使用Angular CLI快速创建Angular项目的一些基本概念和写法小结
Apr 22 #Javascript
You might like
DC的38部超级英雄动画电影
2020/03/03 欧美动漫
分享一个php 的异常处理程序
2014/06/22 PHP
反射调用private方法实践(php、java)
2015/12/21 PHP
微信开发之获取JSAPI TICKET
2017/07/07 PHP
PHP内部实现打乱字符串顺序函数str_shuffle的方法
2019/02/14 PHP
thinkPHP框架乐观锁和悲观锁实例分析
2019/10/30 PHP
JCalendar 日历控件 v1.0 beta[兼容IE&Firefox] 有文档和例子
2007/05/30 Javascript
javascript YUI 读码日记之 YAHOO.util.Dom - Part.4
2008/03/22 Javascript
js 取时间差去掉周六周日实现代码
2012/12/25 Javascript
input输入框的自动匹配(原生代码)
2013/03/19 Javascript
用js传递value默认值的示例代码
2014/09/11 Javascript
JQuery自适应窗口大小导航菜单附源码下载
2015/09/01 Javascript
jQuery平滑旋转幻灯片特效代码分享
2015/09/07 Javascript
js获取url传值的方法
2015/12/18 Javascript
对称加密与非对称加密优缺点详解
2017/02/06 Javascript
纯js实现的积木(div层)拖动功能示例
2017/07/19 Javascript
vue.js系列中的vue-fontawesome使用
2018/02/10 Javascript
vue使用rem实现 移动端屏幕适配
2018/09/26 Javascript
小程序实现分类页
2019/07/12 Javascript
.netcore+vue 实现压缩文件下载功能
2020/09/24 Javascript
vant-ui组件调用Dialog弹窗异步关闭操作
2020/11/04 Javascript
简单学习Python time模块
2016/04/29 Python
利用Python破解验证码实例详解
2016/12/08 Python
pandas全表查询定位某个值所在行列的方法
2018/04/12 Python
python sort、sort_index方法代码实例
2019/03/28 Python
python滑块验证码的破解实现
2019/11/10 Python
Pytorch自己加载单通道图片用作数据集训练的实例
2020/01/18 Python
Glamest意大利:女性在线奢侈品零售店
2019/04/28 全球购物
澳大利亚购买健身器材网站:Gym Direct
2019/12/19 全球购物
巴西购物网站:Submarino
2020/01/19 全球购物
华为慧通笔试题
2016/04/22 面试题
毕业实习个人鉴定范文
2013/12/10 职场文书
大学英语演讲稿范文
2014/04/24 职场文书
赵乐秦在党的群众路线教育实践活动总结大会上的讲话稿
2014/10/25 职场文书
优秀毕业生主要事迹材料
2015/11/04 职场文书
2016年党风廉政建设承诺书
2016/03/25 职场文书