前端开发基础6:Node.js和LESS预编译工具

简介: 本实验将介绍如何通过Node.js进行前端预编译。

前端开发基础6:Node.js和LESS预编译工具


1.  创建资源

开始实验之前,您需要先创建实验相关资源。

  1. 在实验室页面,单击创建资源
  2. (可选)在实验室页面左侧导航栏中,单击云产品资源列表,可查看本次实验资源相关信息(例如IP地址、子用户信息等)。

说明:资源创建过程需要3~5分钟视资源不同开通时间有所差异,ACK等资源开通时间较长。完成实验资源的创建后,您可以在云产品资源列表查看已创建的资源信息,例如:子用户名称、子用户密码、AK ID、AK Secret、资源中的项目名称等。

实验环境一旦开始创建则进入计时阶段,建议学员先基本了解实验具体的步骤、目的,真正开始做实验时再进行创建。

资源创建成功,可在左侧的资源卡片中查看相关资源信息以及RAM子账号信息

2.  进入VNC实验环境

  1. 进入网页环境。

在远程桌面页面中,双击Chromium网页浏览器

  1. 登录RAM用户。

2.1 浏览器启动后会默认打开阿里云的RAM用户登录页面,在RAM用户登录框中单击下一步

2.2 复制粘贴页面左上角的子用户密码用户密码输入框,单击登录

  1. 进入ECS的远程连接。

3.1 登录成功后跳转到控制台,我们在控制台的搜索框中输入ECS,然后单击云服务器ECS进入云服务器控制台。

3.2 在ECS控制台中,我们找到实验创建的ECS,点击右侧的远程连接按钮。

  1. 在远程连接中选择通过VNC远程连接中的立即登录,如果没有显示该选项,则可单击展开其他登录方式

  1. 登录VNC远程连接。

4.1 初次登录VNC远程连接时需要先设置VNC密码。单击重置VNC密码

4.2 输入两次新的VNC密码,并单击确定

4.3 VNC密码设置成功后,输入密码并单击确定

4.4 VNC登录成功后会看到实验ECS的登录界面。

说明:dev账户的登录密码为 Dev12345

3.  node.js的简介和安装

在前面的实验中我们学习了,如何利用前台脚本加载LESS格式的样式表,但是当LESS样式表比较复杂时,这种前台加载的方法会影响网页的加载速度。因此对于比较复杂的项目,一般会在服务器端对LESS样式表做预先的编译和处理,将LESS样式表编译成CSS。而在前端开发中,服务器端预处理平台我们一般会选择node.js。

  1. Node.js的简介和下载。

Node.js是一个基于Chrome中的V8   JavaScript运行引擎开发的后端JavaScript运行环境。由于Node.js的运行环境源于前端浏览器,因此两者的开发方法高度相通,大大简化了前端开发环境的技术转换门槛,因此在前端开发中,服务器端业务大多使用Node.js环境。

接下来我们来学习一下Node.js环境的安装,我们打开Edge浏览器,访问node.js官网下载地址 https://nodejs.org/en/download/。为了保证稳定性我们选择LTS长期维护版本。接下来看到Linux Binaries(x64)操作系统64-bit平台的下载连接。

由于node.js官方网站的下载速度较慢,因此我们安装包将上传到OSS了,同学们可以在浏览器地址栏中输入https://labfileapp.oss-cn-hangzhou.aliyuncs.com/PracticalTrain/node-v18.14.2-linux-x64.tar.xz进行下载。下载完毕后,点击打开文件夹。打开文件应用。

  1. node的安装。

2.1 由于node.js没有提供deb方式的安装包。因此我们需要手动进行安装。在文件应用中,单击地址栏右侧的菜单按钮,选择在终端打开(E),进入终端应用。

2.2 接下来进行解压缩,复制文件和建立软连接,在终端中输入如下代码后按回车.

xz -d node-v18.14.0-linux-x64.tar.xz
tar xvf node-v18.14.0-linux-x64.tar
sudo mv node-v18.14.0-linux-x64 /usr/local/node
echo "export PATH=/usr/local/node/bin:$PATH" >> ~/.bashrc 
source ~/.bashrc

2.3 命令之后输入dev用户的密码Dev12345,命令执行成功后,我们来验证,执行如下命令.

node -v
npm -v

版本信息显示成功表示node安装成功。

  1. node命令的的基本用法。

3.1 通过上一个步骤将Node.js安装好之后,会在/usr/local/node/bin中安装命令工具。我们在终端中执行如下命令。

ls /usr/local/node/bin/

返回结果如下,我们会发现18.14版本的Node.js提供了4个命令行工具。

3.2 我们首先来介绍node命令,我们在终端中执行如下命令。

node

返回结果如下,在执行node命令之后,我们进入了一个类似python的node脚本运行环境。

3.3 在node运行环境中,我们可以执行JavaScript命令。执行如下命令。

console.log("Hello World");

返回结果如下,即可实时输出脚本运行的结果。运行完毕后按下Ctrl + C两次,即可退出node环境。

4.  npm工具的基本用法

在上一小节中,我们学习了如何安装Node.js以及node命令的基本用法。本小节中,我们来学习如何利用Node.js进行less的预编译。

  1. npm命令的基本用法。

npm命令是除了node命令之外另一个非常重要的命令,它的作用是管理Node.js中庞大的扩展包资源。Node.js作为一个开放的平台,他的常用命令只有四个,而其他的功能都是以扩展插件的形式进行提供。用户如果需要使用某些功能,就可以使用npm来安装扩展资源。

使用npm的安装扩展资源,基本上可以分为两种,一种是全局型资源,一种是项目型资源。全局型资源安装在node目录中,而项目型资源安装在项目所在目录中,为了能通过npm管理和安装项目型资源,我们首先需要通过npm init命令对项目进行初始化。我们在终端中执行如下命令。

npm init

会看到命令执行后会弹出很多的配置项,此处我们可以使用默认设置,连续按回车即可。

项目初始化完成之后,我们会发现目录下自动生成了package.json文件。我可以用vscode打开这个文件,这个文件就是node.js项目的配置文件,在后面的实验中,我们会逐步讲解这个配置文件的用处。

  1. 通过npm安装Less的编译模块。

除了初始化项目之外,npm工具最常用的用法就是通过npm install 组件名命令安装第三方组件,在npm install命令中可以选择使用-g参数,使用这个参数会将资源以全局型的方式安装,接下来我们通过npm来安装less组件模块。在终端入如下内容。

npm install less -g
ls /usr/local/node/bin

我们可以看到全局型资源被到Node.js的bin目录中。这样的好处是我们在使用的时候不必再配置环境变量。即可随时使用。

  1. lessc命令的验证。

接下来我们验证lessc命令,我们在终端入如下内容。版本信息输出正确表示安装成功。

lessc -v

5.  Less样式表的预编译处理

  1. 初始化LESS样式表.

我们首先通过vscode在/home/dev/web中创建并保存style.less文件。文件中如下内容。

@dark: #141414;
@light: #f4f4f4;
@control-border: #777777;
@defbtn: #3060C0;
@cancelbtn: #a4a4a4;
@lightbtn: lighten(@defbtn, 20%);
.autocolor(@color){
    background-color: @color;
    color: if((hsvsaturation($background-color) > 60%), @light, @dark);
}
body {
    background-color: @light;
    color: @dark;
    button {
        .autocolor(@defbtn);
        &.light { 
            .autocolor(@lightbtn);
        }
        &.cancel {
            .autocolor(@cancelbtn);
        }
    }
}
  1. 编译LESS样式表。

lessc命令安装好之后即可用来编译LESS样式表,lessc命令的使用非常简单,只需要在lessc后加入需要编译的文件名和编译后的文件名即可。在终端中运行如下命令

cd /home/dev/web
lessc style.less style.css
cat style.css

即可看到less样式表编译后的结果。

  1. 加载样式表。

继续修改index.html文件为如下内容,通过<link>标签加载style.css

<!DOCTYPE html>
<html lang="zh-CN">
<link href="style.css" rel="stylesheet" type="text/css" />
<title>Web dev</title>
<body>
    <div>
        <button class="">button</button>
        <button class="light">light button</button>
        <button class="cancel">cancel button</button>
    </div>
</body>
</html>

编译完成后再vscdoe中打开index.html,发现样式表已经生效。

6.  Less预编译的常见用法

  1. lessc工具的其他用法

除了编译less样式表之外,lessc工具还提供了一些辅助功能。例如less样式表的错误检查。接下来我们利用vscode修改less样式文件并再vscode中直接执行终端指令。

1.1 我们打开vscode编译器,通过vscdoe编译器打开style.less文件并修改为如下内容。然后按Ctrl + S保存。

@import "color.less";
@import "size.less";
```

1.2 保存完毕,我们在vscode下方的终端选项卡中,操作终端,输入如下内容。

lessc -l style.less

我们发现通过lessc -l命令在执行时,检查到了style.less中的文本错误。

1.3 我们再将style.less文件改回原来的内容,并再次执行lessc -l命令,检查无输出表示正常。

@import "color.less";
@import "size.less";
lessc -l style.less

  1. 利用npm安装less插件。

除了常用的参数之外lessc命令还支持扩展插件功能,通过插件我们可以调整lessc命令的输出结果,接下来我们来尝试一个使用比较多的less-plugin-clean-css插件,首先我可以通过npm来安装这个插件,在的终端中输入如下命令,注意此处我们使用了npm i简写代替了npm install

npm i less-plugin-clean-css -g

  1. less-plugin-clean-css插件的使用。

插件安装完毕后我们执行如下命令,注意对于以less-plugin-开头的插件,我们可以用--进行替换。

lessc --clean-css style.less style.css

执行完成后,我们在vscode中打开style.css,会发现这是的样式表已经按照压缩的方式进行了处理,这种压缩过的文件虽然不方便开发人员阅读,但是占用的空间小,适合再项目编写完毕后的打包上线发布时使用。

编译完成后再vscdoe中打开index.html,发现压缩过的样式表的效果和未压缩过的一致。

实验链接:https://developer.aliyun.com/adc/scenario/9caa3309dd144cb68c59d1e2dcf4dab3

相关实践学习
2分钟自动化部署人生模拟器
本场景将带你借助云效流水线Flow实现人生模拟器小游戏的自动化部署
7天玩转云服务器
云服务器ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,可降低 IT 成本,提升运维效率。本课程手把手带你了解ECS、掌握基本操作、动手实操快照管理、镜像管理等。了解产品详情:&nbsp;https://www.aliyun.com/product/ecs
相关文章
|
2月前
|
JavaScript 前端开发 程序员
前端原生Js批量修改页面元素属性的2个方法
原生 Js 的 getElementsByClassName 和 querySelectorAll 都能获取批量的页面元素,但是它们之间有些细微的差别,稍不注意,就很容易弄错!
|
6天前
|
机器学习/深度学习 人工智能 自然语言处理
DeepSeek Artifacts:在线实时预览的前端 AI 编程工具,基于DeepSeek V3快速生成React App
DeepSeek Artifacts是Hugging Face推出的免费AI编程工具,基于DeepSeek V3,支持快速生成React和Tailwind CSS代码,适合快速原型开发和前端组件构建。
174 28
DeepSeek Artifacts:在线实时预览的前端 AI 编程工具,基于DeepSeek V3快速生成React App
|
19天前
|
人工智能 前端开发 小程序
2024年12月30日蜻蜓蜻蜓AI工具系统v1.0.0发布-优雅草科技本产品前端源代码已对外开源可免费商用-优雅草老八
2024年12月30日蜻蜓蜻蜓AI工具系统v1.0.0发布-优雅草科技本产品前端源代码已对外开源可免费商用-优雅草老八
2024年12月30日蜻蜓蜻蜓AI工具系统v1.0.0发布-优雅草科技本产品前端源代码已对外开源可免费商用-优雅草老八
|
10天前
|
存储 资源调度 JavaScript
npm、cnpm 和 pnpm 是三种常用的 Node.js 包管理工具
npm、cnpm 和 pnpm 是三种常用的 Node.js 包管理工具。npm 是官方默认的包管理器,提供依赖管理、安装和更新等功能;cnpm 是由阿里巴巴开发的 npm 镜像,专为中国大陆用户优化,解决下载速度慢的问题;pnpm 通过硬链接技术提高安装速度并节省磁盘空间,特别适合磁盘资源紧张的环境。三者命令类似,但各有特色,开发者可根据需求选择合适的工具。
58 5
|
1月前
|
前端开发 JavaScript 开发者
前端项目代码规范工具 (ESLint. Prettier. Stylelint. TypeScript)
前端项目代码规范工具 (ESLint. Prettier. Stylelint. TypeScript)
109 4
|
2月前
|
JavaScript 前端开发 Java
springboot解决js前端跨域问题,javascript跨域问题解决
本文介绍了如何在Spring Boot项目中编写Filter过滤器以处理跨域问题,并通过一个示例展示了使用JavaScript进行跨域请求的方法。首先,在Spring Boot应用中添加一个实现了`Filter`接口的类,设置响应头允许所有来源的跨域请求。接着,通过一个简单的HTML页面和jQuery发送AJAX请求到指定URL,验证跨域请求是否成功。文中还提供了请求成功的响应数据样例及请求效果截图。
springboot解决js前端跨域问题,javascript跨域问题解决
|
2月前
|
前端开发 数据处理 Android开发
Flutter前端开发中的调试技巧与工具使用方法,涵盖调试的重要性、基本技巧如打印日志与断点调试、常用调试工具如Android Studio/VS Code调试器和Flutter Inspector的介绍
本文深入探讨了Flutter前端开发中的调试技巧与工具使用方法,涵盖调试的重要性、基本技巧如打印日志与断点调试、常用调试工具如Android Studio/VS Code调试器和Flutter Inspector的介绍,以及具体操作步骤、常见问题解决、高级调试技巧、团队协作中的调试应用和未来发展趋势,旨在帮助开发者提高调试效率,提升应用质量。
67 8
|
2月前
|
JavaScript
如何使用内存快照分析工具来分析Node.js应用的内存问题?
需要注意的是,不同的内存快照分析工具可能具有不同的功能和操作方式,在使用时需要根据具体工具的说明和特点进行灵活运用。
57 3
|
2月前
|
JSON 前端开发 JavaScript
聊聊 Go 语言中的 JSON 序列化与 js 前端交互类型失真问题
在Web开发中,后端与前端的数据交换常使用JSON格式,但JavaScript的数字类型仅能安全处理-2^53到2^53间的整数,超出此范围会导致精度丢失。本文通过Go语言的`encoding/json`包,介绍如何通过将大整数以字符串形式序列化和反序列化,有效解决这一问题,确保前后端数据交换的准确性。
61 4
|
2月前
|
监控 前端开发 JavaScript
前端稳定性工具-Sentry
【11月更文挑战第9天】Sentry 是一个开源的错误和性能监控平台,支持多种编程语言和框架。它能够捕获前端应用中的各种错误和性能问题,提供详细的错误信息和用户行为关联,帮助开发团队快速定位和解决问题,优化应用性能。但需注意隐私保护、数据准确性和成本控制。
175 3