前言 我们都知道 React 非常优秀并且非常出色,我们可以使用 create-react-app 快速搭建一个前端应用。...但是由于 React 构建出来的只是前端静态资源(如:HTML、CSS 、JS 等),往往不能独立部署,我们还需要一个 WEB 服务器,还需要调用 API; 在本文中,我将使用 React 和 NodeJS...介绍下如何让 Node.js 作为 web 服务器来加载 React 构建出的静态资源,如何让 React 程序可以直接调用 NodeJS API。...创建项目目录 首先我们用命令行创建一个 my-app 的目录,并且进入到 my-app $ mkdir my-app $ cd my-app 初始化 React 程序 然后使用 create-react-app...创建一个 React 程序,这部分是客户端的代码, 所以命名为 client $ npx create-react-app client 使用 NodeJS 来实现我们的 API 创建 API 目录
Blob 对象需要使用FileReader的readAsArrayBuffer解析读取, //而使用 FormData 的最大优点就是可以存储二进制文件 //详情请参考:https...https://developer.mozilla.org/zh-CN/docs/Web/API/FileReader/readAsArrayBuffer (2) 如果要用Json格式发送片文件的话,需要使用...FileReader的readAsArrayBuffer解析,参考: 使用js FormData传文件流,传json(重点)(https://www.jianshu.com/p/80e133a16d5e...) 为图方便,我们使用FormData来直接存储并发送二进制文件。...(3) Object可以存储Blob类型的对象,但在传输的时候Blob类型文件会被序列化成空对象{ } (4) 后端知道切片上传是否完全的方式有两种: 第一种就是前端塞了chunkNumber属性告知后端切片的数量
pathinfo/pathname风格参数如下: 例如: /detail/1/economy (detail/:id/:type)
如果你是一名摄影工作者,那么你的电脑里肯定会保存很多的图片,为了更好的整理和保存这些图片,比如一类主题的图片以相同文字命名并且编号,这样就方便以后查找了,解决办法有了,那么怎么给这么多图片命名并编号呢?...必须是重命名的放大,这样可以一键修改文件名,但是这样修改后的图片名称虽然有编号,但是编号外面加了一层括号,比较难看,很多小伙伴不想要这个括号,所以今天小编就为大家详细介绍“图片批量重命名编号不要括号”的方法...”软件包,然后安装并打开软件,点击两个“添加文件”中的任意一个,将需要重命名的图片全部导入到软件中,可以导入不同文件夹中的图片。...01”的位数是2)。...步骤4,查看案例修改的图片文件名可以看到,批量命名后的图片名整齐规范有编号,并且没有括号。 将电脑中的文件整理的更有规范,有助于提高我们的工作效率,对于工作性质涉及较多文件的小伙伴来说更需要如此。
通过http模块中的request事件可以得到在服务端拿到客户端的有关url的数据(req.url),其中req.url得到的数据是端口号后的所有路径,之后通过调入url模块对获取到的req.url进行操作...再通过url下的parse()方法,获得与该路径的所有相关信息,其中pathname(路径名称)通过不同的路径名称可以调用不同的页面。...querystring模块的使用针对post提交和get提交 通过http模块中的request事件可以得到在服务端拿到客户端的提交方式:method 1.操作为:req.method ...(url.parse(req.url).query)//get类型获取查询字符串 获取类型为:一个对象 { username: 'ss', password: 'ss' } 2)针对post需要使用...request事件返回的‘data’事件(操作数据)和‘end’事件(操作数据结束)。
==react-redux==等插件,使用==antd-mobile==的ui框架。...React-router:是一个基于 React 之上的强大路由库,它可以让你向应用中快速地添加视图和数据流,同时保持页面与 URL 间的同步。...【后端】 NodeJs:使用 express 构建一个本地 HTTP server 来调试 React 项目 MongoDB: 存储用户数据和聊天数据的非关系型数据库 Express: Node的基于...【自动化构建】 create-react-app: 官网提供的react脚手架工具,快速初始化项目代码 eslint: 代码风格检查工具,规范代码书写 技术详解 react中注意的地点 绑定事件,state...传递进来 聊天数据的展示 主要是使用socket.io 实现数据通信原理 后端使用express+socketio的结合,前端监听端口号9000以后,进行了数据的交互和接收 我们在每条数据上 加上了其他的一些值
Node.js 的官网地址: https://nodejs.org/zh-cn (opens new window) # Node.js可以做什么 Node.js 作为一个 JavaScript 的运行环境...# fs 文件系统模块 导入使用: const fs = require('fs') # readFile() 读取指定文件中的内容 语法: const fs = require('fs') fs.readFile...导入使用: const path = require('path') # path.join() 用来将多个路径片段拼接成一个完整的路径字符串 语法: path.join([...paths]) 例子...) resolveHTML(dataStr) }) // 3.1 定义处理 css 样式的方法 function resolveCSS(htmlStr) { // 3.2 使用正则提取需要的内容...导入使用: const http = require('http') # http.createServer() 调用 http.createServer() 方法,即可快速创建一个 web 服务器实例
}; /** *诗 表 */ const Poetry = mongoose.model('poetry', new Schema({ title : String, //诗的标题...author : String, //作者 href : String, //链接 content: String, //诗的内容 dynasty...if (err) { console.log(err.message); } else { console.log("^_^数据库已连接...请开始你的表演
在本教程中,我们将在服务器和客户端使用 TypeScript、React、NodeJS、Express 和 MongoDB 从头开始构建一个 Todo 应用程序。 我们从设计 API 开始。...因为默认情况下,这个应用程序会使用 JavaScript。 在 NodeJS 应用程序中有两种使用 TypeScript 的方法,要么在项目中本地安装使用,要么在电脑中全局安装使用。...但如果你想,你也可以坚持使用本地安装使用的方式。 现在,让我们在终端上执行以下命令来安装 TypeScript。...用 React 和 TypeScript 创建客户端 构建 为了创建一个新的 React 应用,我将会使用 create-react-app ——你可以用其他你想用的方法。...最后,我们使用 TypeScript、React、NodeJs、Express 和 MongoDB 完成了一个 Todo 应用程序的构建。 附上源代码。 谢谢阅读!
一、基本使用 (1).明确两个概念: 1).UI组件:不能使用任何redux的api,只负责页面的呈现、交互等。...(2).如何创建一个容器组件————靠react-redux 的 connect函数 connect(mapStateToProps,mapDispatchToProps...(3).使用了react-redux后也不用再自己检测redux中状态的改变了,容器组件可以自动完成这个工作。...(3).重点:Person的reducer和Count的Reducer要使用combineReducers进行合并, 合并后的总状态是一个对象!!!...四、react-redux开发者工具的使用 (1).npm install redux-devtools-extension (2).store中进行配置
因为http会话的无状态性,为了标记用户的登录状态,便出现了cookie。...cookie、session的区别: cookie数据存放在客户的浏览器上,session数据放在服务器上。...cookie不是很安全,别人可以分析存放在本地的COOKIE并进行COOKIE欺骗 考虑到安全应当使用session。 session会在一定时间内保存在服务器上。...当访问增多,会比较占用你服务器的性能 考虑到减轻服务器性能方面,应当使用COOKIE。 单个cookie保存的数据不能超过4K,很多浏览器都限制一个站点最多保存20个cookie。...------------'); }); app.use(session({ secret: config.cookieSecret, //secret的值建议使用
一.简介 一般启动nodejs用node app.js 这样可以正常启动应用,但如果断开链接应用也就停止了,虽然可以用如下方法后台防止,但使用Forever可以更好的解决问题。...nohup node app.js & Forever可以守护Node.js应用,断开的情况下,应用也能正常工作。...1.安装forever到全局环境 npm install forever -g 2.查看应用列表 forever list 二.使用 启动 1.最简单的启动方式 forever start ..../bin/www 4.指定node.js应用的控制台输出文件和错误信息输出文件 forever start -o out.log -e err.log ..../bin/www 5.监听当前目录下文件改动,如有改动,立刻重启应用,不推荐的做法!如有日志文件,日志文件是频繁更改的 forever start -w .
core 3.3.0 然后新建个工具类 QrcodeUtil // 图片宽度的一半...* @param width 二维码的宽度 * @param height 二维码的高 * @param destImagePath 生成二维码图片的路径 * @...System.currentTimeMillis(); File destImagePaths = new File(destImagePath); //生成二维码图片文件(不带...} catch (Exception e) { e.printStackTrace(); return false; } } /** * 生成二维码图片文件(不带...LOGO) * * @param content 要生成二维码的内容 * @param width 二维码的高度 * @param height 二维码的宽度 * @return 二维码图片
文章由 @Keefer 授权分享 写这篇文章的目的是想记录下NodeJs(后面简称node)与python的使用对比,希望看完之后大家对node跟python有个基本的认识。...python变量定义直接使用赋值的方式即可:value = 1。python中只有模块、类和函数会引入新的作用域,代码块不会引入新的作用域。...导出模块可以使用exports跟module.exports,而require最终使用的是module.exports对象。...需要注意的是exports跟module.exports虽然使用的是同一个内存地址,但如果对exports赋值了引用类型的值,那么就等于给exports使用了新的内存地址,使用require方法时就无法获取到...总结 node跟python在各自领域都有不错的发展。对node来说前端打包构建、react\vue的同构应用这些场景很难被替代(采用js的好处)。
了解Node NodeJS :主要应用于开发服务器,做数据API ,设计路由,和前端的主要区别在于,前端主要负责效果和交互、 node.js是追求性能极致的产物,主要的三个特点是: 单线程、Non-blocking...I/O、Event Driven Nodejs和其他后端语言的不同: 采用单线程, 所以 需要非阻塞I/O,所以 需要事件驱动。...极大地提高了CPU的利用率: node没有自己的语法,使用V8引擎,用的是js,V8引擎解析js,效率非常高。...(使用路由) 模块:在Node.js中,以模块为单位划分所有的功能,并且提供了一个完成的模块加载机制,我们可以将应用程序划分为各个不同的部分。...都只能在这个文件内部有效;当需要从此文件外部引用这些变量、函数时,必须使用exports进行暴露,然后使用require引用。
---- 这是我参与8月更文挑战的第三天 1.组件介绍 使用React就是在使用组件 组件表示页面中的部分功能 组合多个组件实现完整的页面功能 特点:可复用、独立、可组合 2....组件的两种创建方式 2.1 使用函数创建组件 使用js的函数(箭头函数)创建的组件 约定1:函数名称必须以大写字母开头 ...类组件:使用ES6 的class创建的组件 约定1:类名称必须以大写字母开头 约定2:类组件继承自React.Component父类,从而可以使用父类中提供的方法或属性 约定3:类组件必须提供render...() 方法 约定4:render()方法必须有返回值 表示该组件的结构 class Hello extends React.Component{ render(){ return react-dom'; import '.
Route Route包含在Router中,但更多情况下,我们直接都是把Router放在“根”上,也即App上: import React from "react"; import ReactDom from..."react-dom"; import App from "..../pages/App"; import {BrowserRouter as Router} from "react-router-dom" ReactDom.render( ...嵌套路由 在路由里套路由 所有的组件你都可以使用使用 Link Switch .....一般情形下,如果使用NavLink的话,会自动添加一个名为active的class,如果要自定义,那么给NavLink添加要给属性即可:activeClassName <NavLink to="/hello
Hooks是React 16.8的新增特性。 它可以让你在不编写class的情况下使用state以及其他的React特性。...是一些可以让你在函数组件里“钩入” React state及生命周期等特性的函数。 Hook不能在class组件中使用,这使你不使用class也能使用React。...,使用Hooks与不使用Hooks的区别,后者比前者是更简单的。...通过使用这个 Hook,你可以告诉 React 组件需要在渲染后执行某些操作。React 会保存你传递的函数(我们将它称之为 “effect”),并且在执行 DOM 更新之后调用它。...使用Hook useEffect的示例 import React, { useState, useEffect } from 'react'; function FriendStatus(props)
这是第 115 篇不掺水的原创,想要了解更多,请戳上方蓝色字体:政采云前端团队 关注我们吧~ 本文首发于政采云前端团队博客:React Profiler 的使用 https://zoo.team/article...Developer Tools 提供的 Profiler 可以直观的帮助大家找出 React 项目中的性能瓶颈,进一步来改善我们的应用,推荐给大家安装使用。...使用 安装 可以从 Chrome 应用市场、Firefox 浏览器扩展、Node 包 下载安装; react 16.5+ 开发模式下才可以使用该功能,生成环境使用请移步官方文档 (https://fb.me...: 很明显,未加优化的 Length100List 占用了大部分 commit 时间,而这个时间很明显是不必要的,我们使用 React.memo 来阻止 List 的不必要渲染。...hook 的使用,这样的优化场景已经大大减少了; import React from "react"; import { is } from "immutable"; export default class
领取专属 10元无门槛券
手把手带您无忧上云