IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> Node应用开发入门 -> 正文阅读

[JavaScript知识库]Node应用开发入门

开发工具: Visual Studio Code

1.创建Node应用程序目录,并进入该目录,右键单击,在弹出的菜单中选择通过Code打开
2.按快捷键Ctrl+`(反引号)打开终端(Terminal),然后输入命令

npm init -y

-y参数表示项目使用默认的配置参数。
3.安装Webpack开发包,输入命令

npm install webpack webpack-cli --save-dev

其中webpack-cli表示webpack的命令行工具,另外使用参数--save-dev表示该安装包为调试开发时的依赖项,信息记录到package.json文件中的devDependencies子项中,后期项目发布时不需要这些安装包。
4.在根目录下新建index.html,在空白页面最开始处输入字符!,然后会激活并弹出一个快捷输入方式,选中!选项直接回车,代码会自动生成。
5.在根目录下新建src子目录,在该子目录下新建index.js,输入如下代码

document.write('Hello Node');

6.修改index.html,引用index.js

<!DOCTYPE html>
<html>
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Hello</title>
</head>
<body>
  <script src="./src/index.js"></script>
</body>
</html>

7.更新package.json

{
  "name": "vueprojects",
  "version": "1.0.0",
  "private": "true",
  "scripts": {
    "test": "echo \"Error: no test specified\" && exit 1"
  },
  "keywords": [],
  "author": "",
  "license": "ISC",
  "devDependencies": {
    "webpack": "^5.67.0",
    "webpack-cli": "^4.9.2"
  }
}

添加private参数,确保我们的安装包是私有的;同时移除main入口,防止意外发布应用代码。
到此,就可以简单的测试一下该Node应用了,在浏览器中打开index.html
8.创建分发(dist)目录结构,在根目录新建dist目录,将index.html移入其中.安装Lodash

npm i --save lodash

修改index.js

import _ from "lodash";

function divComp() {
  let eleDiv = document.createElement('div');
  eleDiv.innerHTML = _.join(['Hello', 'Webpack', '!'], ' ');
  
  return eleDiv;
}

document.body.appendChild(divComp());

修改index.html

<!DOCTYPE html>
<html>
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Hello</title>
</head>
<body>
  <script src="main.js"></script>
</body>
</html>

9.通过Webpack打包Node应用

npx webpack

npx命令是从NPM5.2+版本开始提供的命令,可以自动执行npm包内的二进制安装文件。
通过Webpack打包后自动生成main.js(bundle包文件,一个经过代码压缩的打包文件,提高运行速度)。至于后面的警告信息先不用理会,后面会通过相关配置消除该警告信息。
此时可以再次测试这个Node应用,在浏览器中打开index.html
10.使用Webpack配置文件,在根目录下新建webpack.config.js,输入代码

const path = require('path');

module.exports = {
  entry: './src/index.js',
  output: {
    filename: 'bundle.js',
    path: path.resolve(__dirname, 'dist')
  },
  mode: 'development'
}

通过mode参数配置打包模式(development表示开发模式,该模式会对脚本代码进行压缩)。
11.重新配置package.json配置文件,在scripts节点下添加一个build参数

"scripts": {
  "test": "echo \"Error: no test specified\" && exit 1",
  "build": "webpack"
},

12.再次修改index.jsindex.html

import _ from "lodash";

function divComp() {
  let eleDiv = document.createElement('div');
  eleDiv.innerHTML = _.join(['Hello', 'Webpack', '&', 'Nodejs', '!'], ' ');
  
  return eleDiv;
}

document.body.appendChild(divComp());
<!DOCTYPE html>
<html>
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Hello</title>
</head>
<body>
  <script src="bundle.js"></script>
</body>
</html>

13.再次通过Webpack工具打包Node应用,由于在package.json配置文件中的scripts节点中重新定义了脚本执行命令,因此需要输入新的命令来执行Webpack打包操作

npm run build

build参数是在package.json配置文件中定义的。由于在webpack.config.js中配置了mode参数。
此时可以再次测试这个Node应用,在浏览器中打开index.html
14.通过webpack-dev-server插件实现Node应用热加载,安装

npm install webpack-dev-server --save-dev

package.jsonscripts节点中新增一个dev参数

"scripts": {
  "test": "echo \"Error: no test specified\" && exit 1",
  "build": "webpack",
  "dev": "webpack-dev-server"
}

修改webpack.config.js

const path = require('path');

module.exports = {
  entry: './src/index.js',
  output: {
    filename: 'bundle.js',
    path: path.resolve(__dirname, 'dist')
  },
  mode: 'development',
  devServer: {
    static: './dist'
  }
}

然后运行命令执行打包操作

npm run dev

15.配合HotModuleReplacementPlugin插件实现Node应用热更新,修改webpack.config.js

const path = require('path');
const webpack = require('webpack');

module.exports = {
  entry: './src/index.js',
  output: {
    filename: 'bundle.js',
    path: path.resolve(__dirname, 'dist'),
    clean: true
  },
  mode: 'development',
  devServer: {
    static: './dist',
    hot: true
  },
  plugins: [
    new webpack.HotModuleReplacementPlugin()
  ]
}

再次运行

npm run dev

然后修改index.html或者index.js可以看到,页面实现了热加载。

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-02-01 20:30:57  更:2022-02-01 20:32:52 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/9 14:35:09-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码