JS进行前后端同构步骤详解

这次给大家带来JS进行前后端同构步骤详解,JS进行前后端同构的注意事项有哪些,下面就是实战案例,一起来看一下。

什么是前后端同构

明确三个概念:「后端渲染」指传统的 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参数,加载跟前端共用的模板,配合数据进行渲染,发送到浏览器。

相信看了本文案例你已经掌握了方法,更多精彩请关注【创想鸟】其它相关文章!

推荐阅读:

vue-devtools安装步骤详解

js与typescript中class使用详解

以上就是JS进行前后端同构步骤详解的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2767157.html

(0)
上一篇 2025年3月8日 11:32:08
下一篇 2025年3月7日 22:02:29

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • Angular+Font-Awesome步骤详解

    这次给大家带来Angular+Font-Awesome步骤详解,使用Angular+Font-Awesome的注意事项有哪些,下面就是实战案例,一起来看一下。 前言 本文主要给大家介绍了关于以Angular的姿势打开Font-Awesome…

    编程技术 2025年3月8日
    200
  • vue移动端实现下拉刷新步骤详解

    这次给大家带来vue移动端实现下拉刷新步骤详解,vue移动端实现下拉刷新的注意事项有哪些,下面就是实战案例,一起来看一下。 看完这篇文章,相信大伙也一样可以,做出一个自己的刷新,加载的组件 说这个功能之前,大家要先了解一下,要怎么触发滚动条…

    2025年3月8日
    100
  • nodejs读取去重excel步骤详解

    这次给大家带来nodejs读取去重excel步骤详解,nodejs读取去重excel的注意事项有哪些,下面就是实战案例,一起来看一下。 如何使用,直接上代码 /** * 安装node-xlsx插件 */var path = require(…

    编程技术 2025年3月8日
    200
  • Vue.js中router如何传递参数

    这次给大家带来Vue.js中router如何传递参数,Vue.js中router传递参数的注意事项有哪些,下面就是实战案例,一起来看一下。 Vue-router参数传递 为什么要在router中传递参数 设想一个场景,当前在主页中,你需要点…

    2025年3月8日
    200
  • vue-cli3.0配置详解

    这次给大家带来vue-cli3.0配置详解,使用vue-cli3.0配置的注意事项有哪些,下面就是实战案例,一起来看一下。 新建项目 # 安装npm install -g @vue/cli# 新建项目vue create my-projec…

    2025年3月8日
    200
  • 源生js实现哈夫曼编码步骤详解

    这次给大家带来源生js实现哈夫曼编码步骤详解,源生js实现哈夫曼编码的注意事项有哪些,下面就是实战案例,一起来看一下。 原始版 function cal(str) { if (typeof str !== ‘string’ || str.l…

    编程技术 2025年3月8日
    200
  • Angular CLI创建Angular项目步骤详解

    这次给大家带来Angular CLI创建Angular项目步骤详解,Angular CLI创建Angular项目的注意事项有哪些,下面就是实战案例,一起来看一下。 开始项目前,你需要先安装node和npm,然后执行npm install -…

    编程技术 2025年3月8日
    200
  • Angularjs中自定义指令使用技巧总结

    这次给大家带来Angularjs中自定义指令使用技巧总结,Angularjs中自定义指令使用的注意事项有哪些,下面就是实战案例,一起来看一下。 一:自定义指令常用模板 下面是大致的说明,不是全面的,后面来具体说明一些没有提及的细节和重要的相…

    编程技术 2025年3月8日
    200
  • jQuery插件highslide.js控制图片案例详解

    这次给大家带来jQuery插件highslide.js控制图片案例详解,jQuery插件highslide.js控制图片的注意事项有哪些,下面就是实战案例,一起来看一下。 前言 今天用用了一款图片展示插件highslide.js,感觉用起来…

    2025年3月8日 编程技术
    200
  • JQuery元素操作详解

    这次给大家带来JQuery元素操作详解,JQuery元素操作的注意事项有哪些,下面就是实战案例,一起来看一下。 第一步:sizzle选择器 基于元素的id、类、类型、属性、属性值等”查找”(或选择)HTML元素,简单…

    编程技术 2025年3月8日
    200

发表回复

登录后才能评论