Vue路由前后端设计总结


Posted in Javascript onAugust 06, 2019

一开始我还以为vue的路由只能用在工程化的项目里面呢,然后研究了一下才发现,在脚本化里面也是可以用的。其实呢不管在哪里用,把原理研究明白就对了。

一、 官网demo

这里不得不吐槽一下官网,写的不清不楚的,在哪里使用都没有说清楚,几行代码一句话就轻飘飘的交代完事了,剩下的事情还得自己研究,比如 HTML5 History API 是怎么回事。这里又涉及了一个问题,想要用好vue,必须的基础是要先掌握的,因为vue的官网教程里面不会管这些基础知识的。

先看官网的代码:

const NotFound = { template: '<p>Page not found</p>' }
const Home = { template: '<p>home page</p>' }
const About = { template: '<p>about page</p>' }

const routes = {
 '/': Home,
 '/about': About
}

new Vue({
 el: '#app',
 data: {
  currentRoute: window.location.pathname
 },
 computed: {
  ViewComponent () {
   return routes[this.currentRoute] || NotFound
  }
 },
 render (h) { return h(this.ViewComponent) }
})

很简单吧就这么几句,浪费了我好多时间才研究明白。恩,好吧还有一个地方每太明白。

首先定义了三个“常量”,就是不能改的那种变量,代表三个页面,或者说是三个模板。分别是404、首页和关于我们。

然后定义了一个路由规则,其实就是一个json,也可以理解为是一个实体类。Key代表url的地址后面的路径和文件名,后面的是我们的真实页面,也就是第一行定义的三个常量。

然后就是常见的vue的实例了,首先需要一个div与之对应,然后是data返回url上面的地址,然后ViewComponent 是根据url地址返回对应的模板(页面)。

最后是render 。大概是实现绑定div的功能吧。

根据这个意思补充了一个页面

<body>
   <span onclick="myURL('/')">首页</span>
   <span onclick="myURL('/about')">关于</span>
   <div id="app"></div>
 </body>

然后呢,运行网页显示 Page not found 404 ,看来路由还是起作用了。那么home和about要怎么出来呢?

二、HTML5 History API

首先要补充一下 HTML5 History API的相关知识,如果已经掌握了那么请略过。

HTML5 History API提供了一种功能,能让开发人员在不刷新整个页面的情况下修改站点的URL。这个功能很有用,例如通过一段JavaScript代码局部加载页面的内容,你希望通过改变当前页面的URL来反应出页面内容的变化,这时该功能可以派上用场。

我们可以用 history.pushState(null, null, ‘about'); 来改变url地址,这种方式只是单纯的修改地址里的url,而不会向服务器提交,这样页面就不会被刷新,我们才有机会执行vue的代码。

然后呢,页面当然是不会有啥变化的,因为vue是数据驱动,我们的数据改变了吗?并没有,我们只是改变了一下url。这个vue似乎没有对rul做监听,或者是我还不知道怎么让vue去监听url的变化,总之我们先自己改变数据,然后再去研究vue有没有办法去监听url。

我们在写一行修改数据的代码route.currentRoute = window.location.pathname就可以了。

最后加一个简单的导航,执行上面两行js代码。

<span onclick="myURL('/')">首页</span>
<span onclick="myURL('/about')">关于</span>

function myURL(name) {
    history.pushState(null, null, name);
    route.currentRoute = window.location.pathname;
}

三、按了F5怎么办?

按F5会刷新页面,如果这时候url地址栏是 “/about” ,那么就会向服务器提交这个网址,很显然会出现服务器的404页面。因为服务器网站里面并没有这个地址。那么怎么办呢?目前想到的办法就是修改网站的404页面。比如IIS,可以到IIS里改一下,把我们做的这个router.html设置为404的响应页面,这样按F5就没事了。

当然这种方式并不是太好的选择,只是一种临时的方法。应该会有更好的方法吧。没事不急慢慢学。

这种方式还支持直接在浏览器的地址栏里面输入 http://127.0.0.1:8000/about 也是可以正常运行的。只需要注意一下vue.js的引用地址确保能够正确加载js文件即可。

那么如果地址栏里输入 http://127.0.0.1:8000/aboutss 呢?当然是vue设计的404模块了。

不过还有一个问题,那个 const About 要怎么改?这种简单的模板没办法做复杂应用的呀。也许只有在工程化的项目里,路由才能发挥最大的作用吧。

感谢大家的阅读和对三水点靠木的支持。

Javascript 相关文章推荐
两个SUBMIT按钮,如何区分处理
Aug 22 Javascript
cloudgamer出品ImageZoom 图片放大效果
Apr 01 Javascript
jquery自定义属性(类型/属性值)
May 21 Javascript
js快速排序的实现代码
Dec 08 Javascript
js实现鼠标经过时图片滚动停止的方法
Feb 16 Javascript
javascript与css3动画结合使用小结
Mar 11 Javascript
基于javascript制作经典传统的拼图游戏
Mar 22 Javascript
AngularJS入门教程中SQL实例详解
Jul 27 Javascript
JS正则表达式修饰符中multiline(/m)用法分析
Dec 27 Javascript
JavaScript中最常见的三个面试题解析
Mar 04 Javascript
在Create React App中启用Sass和Less的方法示例
Jan 16 Javascript
vue脚手架项目创建步骤详解
Mar 02 Vue.js
vue实现行列转换的一种方法
Aug 06 #Javascript
微信小程序点餐系统开发常见问题汇总
Aug 06 #Javascript
详解使用WebPack搭建React开发环境
Aug 06 #Javascript
vue-cli3+typescript新建一个项目的思路分析
Aug 06 #Javascript
Vue 中可以定义组件模版的几种方式
Aug 06 #Javascript
angularjs请求数据的方法示例
Aug 06 #Javascript
通过js示例讲解时间复杂度与空间复杂度
Aug 06 #Javascript
You might like
GD输出汉字的函数的分析
2006/10/09 PHP
PHP中使用foreach和引用导致程序BUG的问题介绍
2012/09/05 PHP
ThinkPHP采用GET方式获取中文参数查询无结果的解决方法
2014/06/26 PHP
yii实现创建验证码实例解析
2014/07/31 PHP
PHP GD库生成图像的几个函数总结
2014/11/19 PHP
laravel学习教程之存取器
2016/07/30 PHP
Laravel 5.4向IoC容器中添加自定义类的方法示例
2017/08/15 PHP
高性能web开发 如何加载JS,JS应该放在什么位置?
2010/05/14 Javascript
JS添加删除一组文本框并对输入信息加以验证判断其正确性
2013/04/11 Javascript
js正则表达式的使用详解
2013/07/09 Javascript
JS中如何设置readOnly的值
2013/12/25 Javascript
使用JavaScript判断图片是否加载完成的三种实现方式
2014/05/04 Javascript
jQuery获取元素父节点的方法
2016/06/21 Javascript
JS调用某段SQL语句的方法
2016/10/20 Javascript
AngularJS实现DOM元素的显示与隐藏功能
2016/11/22 Javascript
老生常谈的跨域处理
2017/01/11 Javascript
微信小程序 基础知识css样式media标签
2017/02/15 Javascript
nodejs+websocket实时聊天系统改进版
2017/05/18 NodeJs
JavaScript实现二叉树的先序、中序及后序遍历方法详解
2017/10/26 Javascript
vue+webpack实现异步组件加载的方法
2018/02/03 Javascript
浅谈v-for 和 v-if 并用时筛选条件方法
2019/11/07 Javascript
Vue中nprogress页面加载进度条的方法实现
2020/11/13 Javascript
python shell根据ip获取主机名代码示例
2017/11/25 Python
使用pandas将numpy中的数组数据保存到csv文件的方法
2018/06/14 Python
详解python单元测试框架unittest
2018/07/02 Python
django的ORM模型的实现原理
2019/03/04 Python
python利用tkinter实现屏保
2019/07/30 Python
Python 调用 Windows API COM 新法
2019/08/22 Python
基于Python实现全自动下载抖音视频
2020/11/06 Python
前端隐藏出边界内容的实现方法
2016/04/14 HTML / CSS
Html5 video标签视频的最佳实践
2020/02/26 HTML / CSS
台湾团购、宅配和优惠券:17Life
2017/08/14 全球购物
中东地区为妈妈们提供一切的头号购物目的地:Sprii
2018/05/06 全球购物
初中地理教学反思
2014/01/11 职场文书
2014年驾驶员工作总结
2014/11/18 职场文书
公司人事任命通知
2015/04/20 职场文书