Vue路由,Nodejs安装与配置

Vue路由,Nodejs安装与配置

1.学习Vue的路由
  1. SPA是什么
    单页Web应用(single page application,SPA),就是只有一个Web页面的应用,
    是加载单个HTML页面,并在用户与应用程序交互时动态更新该页面的Web应用程序

    单页面应用程序:
    只有第一次会加载页面, 以后的每次请求, 仅仅是获取必要的数据.然后, 由页面中js解析获取的数据, 展示在页面中
    传统多页面应用程序:
    对于传统的多页面应用程序来说, 每次请求服务器返回的都是一个完整的页面

    优势
    减少了请求体积,加快页面响应速度,降低了对服务器的压力
    更好的用户体验,让用户在web app感受native app的流畅

  2. SPA实现思路和技术点
    1 ajax
    2 锚点的使用(window.location.hash #)
    3 hashchange 事件 window.addEventListener(“hashchange”,function () {})
    4 监听锚点值变化的事件,根据不同的锚点值,请求相应的数据
    5 原本用作页面内部进行跳转,定位并展示相应的内容

路由思路
1、确保引入Vue.vue-router的js依赖
2、首先需要定义组件(就是展示不同的页面效果)
3、需要将不同的组件放入一个容器中(路由集合)
4、将路由集合组装成路由器
5、将路由挂载到Vue实例中
6、定义锚点
7、跳转

  1. 通过vue的路由可实现多视图的单页Web应用(基于html的SPA)
    3.0 引入依赖库

3.1 创建自定义组件,例如:Home和Abort组件
const Home = Vue.extend({});

  注1:extend是构造一个组件的语法器. 你给它参数,他给你一个组件,然后这个组件
       你可以作用到Vue.component这个全局注册方法里,也可以在任意vue模板里使用car组件

  注2:也可以用以前的方式创建和获得组件,效果也是一样的
       Vue.component("button-counter", {...});//创建组件
   var ButtonCounter = Vue.component('button-counter');//获得组件

3.2 定义路由(即路线),
var routes = [{path: ‘/about’,component: About}];

  注1:根路径“/”

3.3 创建路由器实例,然后传 routes 配置
const router = new VueRouter({routes:routes});

  注1:route和router的区别
       route:路线
       router:路由器
       路由器中包含了多个路线

3.4 创建和挂载根实例。
var vm = new Vue({router: router}).$mount(‘#app’);

3.4 前面使用RouterLink和RouterView组件导航和显示

  <!-- 使用RouterLink组件导航. -->
  <!-- <router-link> 默认会被渲染成一个 `<a>` 标签 -->
  <!-- 通过传入 `to` 属性指定链接. -->
  <router-link to="/home">go to Home</router-link>
  <!-- 使用RouterView组件显示. -->
  <router-view></router-view> 
  1. router-link相关属性
    4.1 to
    表示目标路由的链接
    <router-link to="/home">Home</router-link><!-- 字符串 -->
    <router-link v-bind:to="'home'">Home</router-link><!-- 使用 v-bind 的 JS 表达式 -->
    
  4.2 replace
      设置 replace 属性的话,当点击时,会调用 router.replace() 而不是 router.push(),导航后不会留下 history 记录。
      ```
      <router-link :to="{ path: '/home'}" replace></router-link>
      ```
  vue中导航中的后退-前进-编程式导航
  this.$router.go(-1) :代表着后退
  this.$router.go(1):代表着前进
  this.$router.push({    切换到name为home的路由
   name:'home'
  });
4.3 append
   设置 append 属性后,则在当前 (相对) 路径前添加基路径。例如,我们从 /a 导航到一个相对路径 b,如果没有配置 append,则路径为 /b,如果配了,则为 /a/b
 
   <router-link :to="{ path: 'relative/path'}" append></router-link>
4.4 有时候想要<router-link>渲染成某种标签,例如<li>。 于是我们使用 tag prop 类指定何种标签,同样它还是会监听点击,触发导航
   <router-link to="/foo" tag="li">foo</router-link>
   <!-- 渲染结果 -->
   <li>foo</li>
4.5 active-class
   设置 链接激活时使用的 CSS 类名。可以通过以下代码来替代

4.6 exact-active-class
   配置当链接被精确匹配的时候应该激活的 class。可以通过以下代码来替代。
  
4.7 event
   声明可以用来触发导航的事件。可以是一个字符串或是一个包含字符串的数组。 
  <router-link v-bind:to = "{ path: '/route1'}" event = "mouseover">Router Link 1</router-link>       
示例
<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
		<script src="https://cdn.bootcdn.net/ajax/libs/vue/2.6.10/vue.js"></script>
		<script src="https://cdn.bootcdn.net/ajax/libs/vue-router/2.6.0/vue-router.js"></script>
	</head>
	<body>
		<div id="app">
			<!-- 发起请求 -->
			<router-link to="/home">首页</router-link>
			<router-link to="/about">关于</router-link>
			<!-- 显示请求内容 -->
			<router-view></router-view>
		</div>
		<script type="text/javascript">
			//1.需要两个组件展示相关业务功能
			var Home = Vue.extend({
				template: '<div>首页所看到的数据内容</div>'
			})
			var About = Vue.extend({
				template: '<div>网站的发展历史以及更新日志</div>'
			})
			//2.要形成组件与请求路径的对应关系
			//2.浏览器访问http://localhost:8080/Home,实际访问的是Home组件
			var routes = [{
				component: Home,
				path: '/home'
			}, {
				component: About,
				path: '/about'
			}];

			//3.引入Vue-router支持
			//4.将路由关系与路由对象绑定
			var router = new VueRouter({
				routes:routes
			});

			const vm = new Vue({
				el: '#app',
				router,
				data: {

				}
			})
		</script>
	</body>
</html>

在这里插入图片描述

2.Nodejs安装
  1. Node.js是什么
    1.1 Node.js是一个基于Chrome V8引擎的[JavaScript运行环境]。 Node.js使用了一个事件驱动、非阻塞式I/O 的模型。
    1.2 Node.js是一个让JavaScript运行在服务端的开发平台,它让JavaScript成为与PHP、Python、Perl、Ruby等服务端语言平起平坐的脚本语言

注1:Node.js–>JavaScript运行环境,开发语言是:javascript
J2EE -->Java运行环境, 开发语言是java
注2:Node.js v10.15.3文档地址:http://nodejs.cn/api/
2. npm是什么
npm其实是Node.js的包管理工具(package manager)。

为啥我们需要一个包管理工具呢?因为我们在Node.js上开发时,会用到很多别人写的JavaScript代码。
如果我们要使用别人写的某个包,每次都根据名称搜索一下官方网站,下载代码,解压,再使用,非常繁琐。
于是一个集中管理的工具应运而生:大家都把自己开发的模块打包后放到npm官网上,如果要使用,
直接通过npm安装就可以直接用,不用管代码存在哪,应该从哪下载。

更重要的是,如果我们要使用模块A,而模块A又依赖于模块B,模块B又依赖于模块X和模块Y,
npm可以根据依赖关系,把所有依赖的包都下载下来并管理起来。否则,靠我们自己手动管理,肯定既麻烦又容易出错。

注1:npm==maven 有点类似

  1. Node.js环境搭建
    由于Node.js平台是在后端运行JavaScript代码,所以,必须首先在本机安装Node环境。
    想一想,java开发的第一步:是不是安装JDK,再配置环境变量java_home/classpath/path

3.1 下载
下载地址:https://nodejs.org/zh-cn/download/
选择相应的版本下载,本章使用的是:node-v10.15.3-win-x64.zip

  注1:Node有两个版本线: LTS是长期维护的稳定版本Current是新特性版本

3.2 解压
将文件解压到指定位置(例如:D:\initPath),并在解压后的目录下建立node_global和node_cache这两个目录

  注1:新建目录说明
       node_global:npm全局安装位置
       node_cache:npm缓存路径

  注2:本教程是将文件解压到D:\initPath目录,后面都以此为例,实际开发中请修改成自己的解压目录
       D:\initPath\node-v10.15.3-win-x64 

3.3 配置环境变量
新增NODE_HOME,值为:D:\initPath\node-v10.15.3-win-x64
修改PATH并在最后添加:;%NODE_HOME%;%NODE_HOME%\node_global;

  注1:环境变量查看
       echo %node_home%
       echo %path%

  注2:测试安装是否成功:打开cmd窗口,输出如下命令会输出NodeJs和npm的版本号
       node -v
       npm -v

3.4 配置npm全局模块路径和cache默认安装位置
打开cmd,分开执行如下命令:
npm config set cache “D:\initPath\node-v10.15.3-win-x64\node_cache”
npm config set prefix “D:\initPath\node-v10.15.3-win-x64\node_global”

  注1:将步骤一创建的node_global(npm全局安装位置)和node_cache(npm缓存路径)与npm联系起来
  注2:如果执行命令卡死,可以删除C:\Users\用户名\.npmrc 后重新执行。(用户名:为当前电脑的用户名)
  注3:"D:\initPath\node-v10.15.3-win-x64\node_global",双引号不能少

3.5 修改npm镜像提高下载速度(可以使用 cnpm 或 直接设置 --registry ,推荐设置 --registry)
3.5.1 --registry
## 设置淘宝源
npm config set registry https://registry.npm.taobao.org/
## 查看源,可以看到设置过的所有的源
npm config get registry

      注1:其实此步骤的内容就是将以下代码添加到C:\Users\用户名\.npmrc文件中
           registry=https://registry.npm.taobao.org
3.5.2 cnpm
      npm install -g cnpm --registry=https://registry.npm.taobao.org

      注1:cnpm安装完成后,以后就可以用cnpm命令代替npm命令, 此时npm还是会用官方镜像,cnpm会用国内镜像
      注2:如果要恢复成原来的设置,执行如下:
           npm config set registry https://registry.npmjs.org/

3.6 验证安装结果
3.6.1 版本验证(同步骤3.3,注2)
node -v
npm -v

3.6.2 查看淘宝镜像设置情况
      npm get registry

3.6.3 查看npm全局路径设置情况
      ## 此步骤随便全局安装一个模块就可以测评
      npm install webpack -g
      ## 以上命令执行完毕后,会生成如下文件
      %node_home%\node_global\node_modules\webpack
	  注意:下载过程中出现warn不用管,出现Error,删掉下载的破碎文件重新下载
  1. 如何运行下载的Node.js项目
    将下载的项目解压到指定目录,本例是解压到:D:\temp\vueproject,后面都以此为例

    1. 打开命令窗口

    cmd

    2. 切换到d盘

    e:

    3. 进入指定目录

    cd E:\temp\vueproject

    下面的才是关键代码

    4. 进行依赖安装

    命令执行完后,你会发现,项目的根目录下多了一个node_modules文件夹,

    那里面就是从npm远程库里下载的模块,然后“安装”到你的项目中,

    此步骤,可理解成修改maven的pom文件添加依赖,然后maven再从中央仓库下载依赖

    那pom文件在哪里呢?其实就是项目中的package.json

    npm install

    5. 启动项目

    npm run dev

npm ERR! code EPERM npm ERR! syscall mkdir
在这里插入图片描述
遇到这种问题修改npm_cache和npm_global文件夹的权限,赋予修改权限

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值