热门标签 | 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讨论交换,互相学习~项目地点在此


推荐阅读
  • 本文介绍了如何使用JavaScript的Fetch API与Express服务器进行交互,涵盖了GET、POST、PUT和DELETE请求的实现,并展示了如何处理JSON响应。 ... [详细]
  • 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机制,解释其原理及应用场景。 ... [详细]
  • libsodium 1.0.15 发布:引入重大不兼容更新
    最新发布的 libsodium 1.0.15 版本带来了若干不兼容的变更,其中包括默认密码散列算法的更改和其他重要调整。 ... [详细]
  • 本文介绍了如何利用npm脚本和concurrently工具,实现本地开发环境中多个监听服务的同时启动,包括HTTP服务、自动刷新、Sass和ES6支持。 ... [详细]
  • 深入解析 Apache Shiro 安全框架架构
    本文详细介绍了 Apache Shiro,一个强大且灵活的开源安全框架。Shiro 专注于简化身份验证、授权、会话管理和加密等复杂的安全操作,使开发者能够更轻松地保护应用程序。其核心目标是提供易于使用和理解的API,同时确保高度的安全性和灵活性。 ... [详细]
  • 本文详细介绍了如何在 Windows 环境下使用 node-gyp 工具进行 Node.js 本地扩展的编译和配置,涵盖从环境搭建到代码实现的全过程。 ... [详细]
  • 本文详细介绍了在企业级项目中如何优化 Webpack 配置,特别是在 React 移动端项目中的最佳实践。涵盖资源压缩、代码分割、构建范围缩小、缓存机制以及性能优化等多个方面。 ... [详细]
  • 创建项目:Visual Studio Online 入门指南
    本文介绍如何使用微软的 Visual Studio Online(VSO)创建和管理开发项目。作为一款基于云计算的开发平台,VSO 提供了丰富的工具和服务,简化了项目的配置和部署流程。 ... [详细]
  • 本文详细探讨了HTML表单中GET和POST请求的区别,包括它们的工作原理、数据传输方式、安全性及适用场景。同时,通过实例展示了如何在Servlet中处理这两种请求。 ... [详细]
  • Struts与Spring框架的集成指南
    本文详细介绍了如何将Struts和Spring两个流行的Java Web开发框架进行整合,涵盖从环境配置到代码实现的具体步骤。 ... [详细]
  • 本文介绍了如何利用 Spring Boot 和 Groovy 构建一个灵活且可扩展的动态计算引擎,以满足钱包应用中类似余额宝功能的推广需求。我们将探讨不同的设计方案,并最终选择最适合的技术栈来实现这一目标。 ... [详细]
  • 基于Node.js、Express、MongoDB和Socket.io的实时聊天应用开发
    本文详细介绍了使用Node.js、Express、MongoDB和Socket.io构建的实时聊天应用程序。涵盖项目结构、技术栈选择及关键依赖项的配置。 ... [详细]
  • 实用正则表达式有哪些
    小编给大家分享一下实用正则表达式有哪些,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下 ... [详细]
  • Redux入门指南
    本文介绍Redux的基本概念和工作原理,帮助初学者理解如何使用Redux管理应用程序的状态。Redux是一个用于JavaScript应用的状态管理库,特别适用于React项目。 ... [详细]
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社区 版权所有