热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

服务端衬着react+mobx+webpack+express实战(同时也支撑客户端衬着)

现在绝大多数网站照样一个多页的构造,但实在一个网站已完全能够做成一个spa,比方youtube就是一个spa,近来公司项目都是采纳react+mobx服务端衬着的单页面运用的情势,

现在绝大多数网站照样一个多页的构造,但实在一个网站已完全能够做成一个spa,比方youtube就是一个spa,近来公司项目都是采纳react+mobx服务端衬着的单页面运用的情势,踩了一些坑,有一些本身的体验,所以把项目抽了出来去掉了营业代码,留了一个架子分享一下。

项目github地点

现在react主流的状况治理运用的比较多的是redux,我司之前有个项目也是react+redux,从我个人运用下来的感觉来讲,关于绝大多数的前端运用场景,mobx远比redux更适宜,更简朴运用,更轻易上手。

结果

上岸,注册

《服务端衬着react+mobx+webpack+express实战(同时也支撑客户端衬着)》

增添item到列表中

《服务端衬着react+mobx+webpack+express实战(同时也支撑客户端衬着)》

假如路由中没有的页面,处置惩罚404

《服务端衬着react+mobx+webpack+express实战(同时也支撑客户端衬着)》

怎样运用

git clone git@github.com:L-x-C/isomorphic-react-with-mobx.git
cd isomorphic-react-with-mobx
npm install

Dev (客户端衬着)

npm start
open http://localhost:3000

Production (服务端衬着)

npm run server
open http://localhost:20000

一些经常会碰到的状况

怎样在服务端猎取数据?

在每一个component中增添一个onEnter,用一个promise来处置惩罚,在这个promise中提议一个action,转变mobx中的states值

@action
static onEnter({states, pathname, query, params}) {
return Promise.all([
menuActions.setTDK(states, '列表'),
jobActions.fetchJobList(states, query)
]);
}

之所以能这么做,是因为在serverRender中有一个onEnter的预处置惩罚,会依据component的嵌套从最外层一向遍历到最里层的onEnter,并实行个中的的要领

import async from 'async';
export default (renderProps, states) => {
const params = renderProps.params;
const query = renderProps.location.query;
const pathname = renderProps.location.pathname;
let OnEnterArr= renderProps.components.filter(c => c.onEnter);
return new Promise((resolve, reject) => {
async.eachOfSeries(onEnterArr, function(c, key, callback) {
let enterFn = c.onEnter({states, query, params, pathname});
if (enterFn) {
enterFn.then(res => {
if (res) {
//处置惩罚Promise回调实行,比方上岸
res.forEach((fn) => {
if (Object.prototype.toString.call(fn) === '[object Function]') {
fn();
}
});
}
if (key === (onEnterArr.length - 1)) {
resolve();
}
callback();
}).catch(err => {
reject(err);
});
} else {
callback();
}
});
});
};

怎样在服务端设置tdk(title, description, keywords)?

这实在在上一个题目中就已涌现了,onEnter中有一个setTDK(states, t, d, k)的要领,运用他就能够设置tdk的值

怎样在服务端举行跳转?

在浏览器环境中,我们能够设置window.location.href = url来举行跳转。
但是在服务器环境中,并没有window和document这2个对象,所以我们在服务器环境中抛出一个非常,然后捕获到以后举行302跳转。
细致能够看src/helpers/location.js, 中的redirect function
他会自动推断当前环境,来挑选运用哪种跳转

import {redirect} from './helpers/location';
@action
static onEnter({states, query, params}) {
redirect('http://www.xxx.com');
}

mobx的道理及运用就不在这里做细致的引见了,网上搜一搜有许多。
我置信我们所采纳的一些要领或许并非最圆满的解法,假如有更好的欢迎来github中提issue讨论交换,互相学习~项目地点在此


推荐阅读
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • 深入解析Java虚拟机(JVM)架构与原理
    本文旨在为读者提供对Java虚拟机(JVM)的全面理解,涵盖其主要组成部分、工作原理及其在不同平台上的实现。通过详细探讨JVM的结构和内部机制,帮助开发者更好地掌握Java编程的核心技术。 ... [详细]
  • 深入解析Spring Cloud Ribbon负载均衡机制
    本文详细介绍了Spring Cloud中的Ribbon组件如何实现服务调用的负载均衡。通过分析其工作原理、源码结构及配置方式,帮助读者理解Ribbon在分布式系统中的重要作用。 ... [详细]
  • libsodium 1.0.15 发布:引入重大不兼容更新
    最新发布的 libsodium 1.0.15 版本带来了若干不兼容的变更,其中包括默认密码散列算法的更改和其他重要调整。 ... [详细]
  • 基于KVM的SRIOV直通配置及性能测试
    SRIOV介绍、VF直通配置,以及包转发率性能测试小慢哥的原创文章,欢迎转载目录?1.SRIOV介绍?2.环境说明?3.开启SRIOV?4.生成VF?5.VF ... [详细]
  • Explore a common issue encountered when implementing an OAuth 1.0a API, specifically the inability to encode null objects and how to resolve it. ... [详细]
  • 深入理解Cookie与Session会话管理
    本文详细介绍了如何通过HTTP响应和请求处理浏览器的Cookie信息,以及如何创建、设置和管理Cookie。同时探讨了会话跟踪技术中的Session机制,解释其原理及应用场景。 ... [详细]
  • 本文详细介绍了 Dockerfile 的编写方法及其在网络配置中的应用,涵盖基础指令、镜像构建与发布流程,并深入探讨了 Docker 的默认网络、容器互联及自定义网络的实现。 ... [详细]
  • 网络攻防实战:从HTTP到HTTPS的演变
    本文通过一系列日记记录了从发现漏洞到逐步加强安全措施的过程,探讨了如何应对网络攻击并最终实现全面的安全防护。 ... [详细]
  • 本文深入探讨了Linux系统中网卡绑定(bonding)的七种工作模式。网卡绑定技术通过将多个物理网卡组合成一个逻辑网卡,实现网络冗余、带宽聚合和负载均衡,在生产环境中广泛应用。文章详细介绍了每种模式的特点、适用场景及配置方法。 ... [详细]
  • 在现代网络环境中,两台计算机之间的文件传输需求日益增长。传统的FTP和SSH方式虽然有效,但其配置复杂、步骤繁琐,难以满足快速且安全的传输需求。本文将介绍一种基于Go语言开发的新一代文件传输工具——Croc,它不仅简化了操作流程,还提供了强大的加密和跨平台支持。 ... [详细]
  • 本文详细记录了在银河麒麟操作系统和龙芯架构上使用 Qt 5.15.2 进行项目打包时遇到的问题及解决方案,特别关注于 linuxdeployqt 工具的应用。 ... [详细]
  • This pull request introduces the ability to provide comprehensive paragraph configurations directly within the Create Note and Create Paragraph REST endpoints, reducing the need for additional configuration calls. ... [详细]
  • 深入解析Java枚举及其高级特性
    本文详细介绍了Java枚举的概念、语法、使用规则和应用场景,并探讨了其在实际编程中的高级应用。所有相关内容已收录于GitHub仓库[JavaLearningmanual](https://github.com/Ziphtracks/JavaLearningmanual),欢迎Star并持续关注。 ... [详细]
  • 深入解析:OpenShift Origin环境下的Kubernetes Spark Operator
    本文探讨了如何在OpenShift Origin平台上利用Kubernetes Spark Operator来管理和部署Apache Spark集群与应用。作为Radanalytics.io项目的一部分,这一开源工具为大数据处理提供了强大的支持。 ... [详细]
author-avatar
手机用户2602903715
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有