Bootstrap

nodejs教程

nodejs教程

1.1 安装

nodejs 可以去官方网站下载,http://nodejs.cn/download/,可以根据自己的操作系统来选择自己需要的版本

node -v  

查看当前的版本号

1.2 编写我们的第一个hello world
var aa ='hello world';
console.log(aa);
=================================================================
Microsoft Windows [版本 6.1.7601]
版权所有 (c) 2009 Microsoft Corporation。保留所有权利。

C:\Users\Administrator>node -v
v8.16.0

C:\Users\Administrator>d:

D:\>cd nodejs

D:\nodejs>dir
 驱动器 D 中的卷是 新加卷
 卷的序列号是 9AFC-4FE4

 D:\nodejs 的目录

2019/09/19 周四  下午 02:02    <DIR>          .
2019/09/19 周四  下午 02:02    <DIR>          ..
2019/09/19 周四  下午 02:03                40 demo_01.js
               1 个文件             40 字节
               2 个目录 44,000,333,824 可用字节

D:\nodejs>node demo_01.js
hello world

D:\nodejs>


1.3 函数的使用

var cc = add(1000,2220);
console.log(cc);

function add(a,b){
	return a+b;
}
D:\nodejs>node demo_02.js
3220

1.4 模块调用
demo_03_1.js

// 被调用的模块。需要导出的方法
exports.add =function(a,b){
	return a+b;
}

demo_03_2.js

// 主模块,去调用刚才的导出的模块

var demo = require('./demo_03_1');

console.log(demo.add(333,555));

D:\nodejs>node demo_03_2
888


1.5 创建web 服务器

var http = require('http');

const server =http.createServer((req,res)=>{
	const body = 'hello world';

  res.writeHead(200, {
    'Content-Length': Buffer.byteLength(body),
    'Content-Type': 'text/plain'
  });
  res.end(body);
	
});
server.listen(8000);


D:\nodejs>node demo_04
 

在这里插入图片描述

1.6 服务端渲染
var http = require('http');

const server =http.createServer((req,res)=>{
	const body = 'hello world';

  res.writeHead(200, {
    'Content-Length': Buffer.byteLength(body),
    'Content-Type': 'text/plain'
  });
  res.write(body+"\n");
  res.end(body);
	
});
server.listen(8000);
console.log("server is runing at http://127.0.0.1:8000 ");


D:\nodejs>node demo_05

通过源码,可以看出来该代码可以看的出来是服务端渲染;

在这里插入图片描述

1.7 参数接收
var http = require('http');

var url = require('url');

http.createServer(function(req,res){
	var body = 'hello world';

  res.writeHead(200, {
    
    'Content-Type': 'text/plain'
  });
  
  
  var data =url.parse(req.url,true).query;
  
  for(var i =0; i<10;i++){
	   res.write("hello wolrd"+"\n");
  };
  
 


  res.end("name="+data.name);
	
}).listen(8000);

console.log("server is runing at http://127.0.0.1:8000 ");



D:\nodejs>node demo_06
server is runing at http://127.0.0.1:8000

浏览器输入:http://localhost:8000/?name=abc

输出结果:
hello wolrd
hello wolrd
hello wolrd
hello wolrd
hello wolrd
hello wolrd
hello wolrd
hello wolrd
hello wolrd
hello wolrd
name=abc

1.8 npm定义

node package manager ,工具类似后端开发中的maven的角色。所以一定要花时间,还有资源站点的收集也是一个重要的任务。

NPM -V  查看版本命令

npm init 初始化项目的



npm install express  本地安装

npm root -g  查看全局安装的路径

npm install jquery -g 全局安装jquery


npm install  在package.json 路径来安装需要的模块。



1.9 淘宝镜像
npm install -g cnpm --registry=https://registry.npm.taobao.org  安装国内淘宝镜像

D:\nodejs\nodeDemo>npm install -g cnpm --registry=https://registry.npm.taobao.org
C:\Users\Administrator\AppData\Roaming\npm\cnpm -> C:\Users\Administrator\AppData\Roaming\npm\node_modules\cnpm\bin\cnpm
+ [email protected]
updated 24 packages in 34.01s

D:\nodejs\nodeDemo>cnpm -v
[email protected] (C:\Users\Administrator\AppData\Roaming\npm\node_modules\cnpm\lib\parse_argv.js)
[email protected] (C:\Users\Administrator\AppData\Roaming\npm\node_modules\cnpm\node_modules\npm\lib\npm.js)
[email protected] (C:\Program Files\nodejs\node.exe)
[email protected] (C:\Users\Administrator\AppData\Roaming\npm\node_modules\cnpm\node_modules\npminstall\lib\index.js)
prefix=C:\Users\Administrator\AppData\Roaming\npm
win32 x64 6.1.7601
registry=https://r.npm.taobao.org

D:\nodejs\nodeDemo>


1.10 运行工程
npm run dev


1.11 编译工程
npm run build



1.12 安装webpack和脚手架
C:\Users\Administrator>cnpm install -g webpack
C:\Users\Administrator>cnpm install -g webpack-cli

C:\Users\Administrator>webpack -v

C:\Users\Administrator>"node"  "C:\Users\Administrator\AppData\Roaming\npm\\node_modules\webpack\bin\webpack.js" -v
4.40.2

C:\Users\Administrator>

1.13 js 打包

bar.js

exports.info= function(str){
	console.log(str);
}

logic.js
exports.add= function(a,b){
    return	a+b;
}
main .js

var bar = require('./bar');
var logic = require('./logic');

bar.info("hello wolrd "+ logic.add(100,2000));

webpack.config.js

const path = require('path');

module.exports = {
  entry: './src/main.js',
  output: {
    path: path.resolve(__dirname, 'dist'),
	//console.log(path.resolve(__dirname, 'dist'));
    filename: 'bundle.js'
  }
};

打包过程:

D:\nodejs\jsdemo>webpack

D:\nodejs\jsdemo>"node"  "C:\Users\Administrator\AppData\Roaming\npm\\node_modules\webpack\bin\webpack.js"
Hash: 0f90a515a71ff262d199
Version: webpack 4.40.2
Time: 136ms
Built at: 2019-09-20 08:37:01
    Asset      Size  Chunks             Chunk Names
bundle.js  1.06 KiB       0  [emitted]  main
Entrypoint main = bundle.js
[0] ./src/main.js 112 bytes {0} [built]
[1] ./src/bar.js 53 bytes {0} [built]
[2] ./src/logic.js 47 bytes {0} [built]

WARNING in configuration
The 'mode' option has not been set, webpack will fallback to 'production' for this value. Set 'mode' option to 'development' or 'production' to enable defaults for each environment.
You can also set it to 'none' to disable any default behavior. Learn more: https://webpack.js.org/configuration/mode/

D:\nodejs\jsdemo>
  
index.html
    
<!doctype html>
<html>
  <head>
    
  </head>
  <body>
  
    <script src="dist/bundle.js"></script>
  </body>
</html>

结果:

在这里插入图片描述

1.14 css 打包

css-loader 是将css装载到JavaScript中;

style-loader 是将JavaScript认识css;

cnpm install style-loader css-loader --save-dev


D:\nodejs\jsdemo>cnpm install style-loader css-loader --save-dev
√ Installed 2 packages
√ Linked 34 latest versions
√ Run 0 scripts
peerDependencies WARNING css-loader@* requires a peer of webpack@^4.0.0 but none was installed
peerDependencies WARNING style-loader@* requires a peer of webpack@^4.0.0 but none was installed
√ All packages installed (37 packages installed from npm registry, used 1s(network 1s), speed 179kB/s, json 36(98.15kB), tarball 123.99kB)

D:\nodejs\jsdemo>cnpm install style-loader css-loader -g --save-dev
Downloading style-loader to C:\Users\Administrator\AppData\Roaming\npm\node_modules\style-loader_tmp
Copying C:\Users\Administrator\AppData\Roaming\npm\node_modules\style-loader_tmp\[email protected]@style-loader to C:\Users\Administrator\AppData\Roaming\npm\node_modules\style-loader
Installing style-loader's dependencies to C:\Users\Administrator\AppData\Roaming\npm\node_modules\style-loader/node_modules
[1/2] loader-utils@^1.2.3 installed at node_modules\[email protected]@loader-utils
[2/2] schema-utils@^2.0.1 installed at node_modules\[email protected]@schema-utils
All packages installed (13 packages installed from npm registry, used 807ms(network 781ms), speed 619.38kB/s, json 13(39.42kB), tarball 444.31kB)
Downloading css-loader to C:\Users\Administrator\AppData\Roaming\npm\node_modules\css-loader_tmp
Copying C:\Users\Administrator\AppData\Roaming\npm\node_modules\css-loader_tmp\[email protected]@css-loader to C:\Users\Administrator\AppData\Roaming\npm\node_modules\css-loader
Installing css-loader's dependencies to C:\Users\Administrator\AppData\Roaming\npm\node_modules\css-loader/node_modules
[1/12] cssesc@^3.0.0 installed at node_modules\[email protected]@cssesc
[2/12] normalize-path@^3.0.0 installed at node_modules\[email protected]@normalize-path
[3/12] camelcase@^5.3.1 installed at node_modules\[email protected]@camelcase
[4/12] postcss-value-parser@^4.0.0 installed at node_modules\[email protected]@postcss-value-parser
[5/12] postcss-modules-values@^3.0.0 installed at node_modules\[email protected]@postcss-modules-values
[6/12] postcss-modules-local-by-default@^3.0.2 installed at node_modules\[email protected]@postcss-modules-local-by-default
[7/12] postcss-modules-extract-imports@^2.0.0 installed at node_modules\[email protected]@postcss-modules-extract-imports
[8/12] icss-utils@^4.1.1 installed at node_modules\[email protected]@icss-utils
[9/12] loader-utils@^1.2.3 installed at node_modules\[email protected]@loader-utils
[10/12] postcss-modules-scope@^2.1.0 installed at node_modules\[email protected]@postcss-modules-scope
[11/12] schema-utils@^2.0.0 installed at node_modules\[email protected]@schema-utils
[12/12] postcss@^7.0.17 installed at node_modules\[email protected]@postcss
All packages installed (35 packages installed from npm registry, used 882ms(network 861ms), speed 1.22MB/s, json 34(85.74kB), tarball 993.23kB)

D:\nodejs\jsdemo>



1.15 vscode

官网下载 https://code.visualstudio.com/

1.15.1 安装

下载64位 windows安装

1.15.2 安装中文语言包

在这里插入图片描述

1.15.3常用插件介绍

VsCode可以通过安装插件来使编辑器变的更加强大

以下为前端开发工程师常用插件

(1)HTML Snippets

超级实用且初级的 H5代码片段以及提示

(2)HTML CSS Support

让 html 标签上写class 智能提示当前项目所支持的样式 新版已经支持scss文件检索

(3)Debugger for Chrome

让 vscode 映射 chrome 的 debug功能,静态页面都可以用 vscode 来打断点调试,真666~

(4)vetur

vue框架所需的插件 语法高亮、智能感知、Emmet等

(5)VueHelper

snippet代码片段

1.15.4 自动保存

点击菜单 :文件–勾选自动保存

悦读

道可道,非常道;名可名,非常名。 无名,天地之始,有名,万物之母。 故常无欲,以观其妙,常有欲,以观其徼。 此两者,同出而异名,同谓之玄,玄之又玄,众妙之门。

;