当前位置: 首页 > news >正文

云南网站建设找三好科技班级优化大师手机版下载(免费)

云南网站建设找三好科技,班级优化大师手机版下载(免费),做网站最清晰的字体,网站制作模版路由的基础知识1.路由简介2.路由基本使用3.嵌套路由4.传递路由的query传参# 5.传递路由的params参数6.路由的props传参配置7.路由router-link标签的replace属性8.编程式路由导航9.缓存路由组件1.路由简介 路由是一条条对应的key-value关系,key就是前端地址栏的路径…

路由的基础知识

  • 1.路由简介
  • 2.路由基本使用
  • 3.嵌套路由
  • 4.传递路由的query传参
  • # 5.传递路由的params参数
  • 6.路由的props传参配置
  • 7.路由router-link标签的replace属性
  • 8.编程式路由导航
  • 9.缓存路由组件

1.路由简介

  • 路由是一条条对应的key-value关系,key就是前端地址栏的路径,value就是对应的组件,用于展示对应内容
  • 路由器:统一管理多条路由
  • 工作过程:当浏览器的地址发生改变时,对应的组件就会显示

2.路由基本使用

  1. 准备路由组件

    //Home组件
    <template><div><h2>我是Home的内容</h2></div>
    </template><script>
    export default {name:'HomeCompo'
    }
    </script>//About组件
    <template><div><h2>我是About的内容</h2></div>
    </template><script>
    export default { name:'AboutCompo'
    }
    </script>
  2. 创建并保留路由配置文件,编写路由规则

    //引入路由需要用到的组件
    import Home from '../components/Home'
    import About from '../components/About'
    //引入路由工具库
    import VueRouter from 'vue-router'
    //创建并暴露路由
    const router=new VueRouter({//配置路由规则routes:[{path:'/home',component:Home},{path :'/about',component:About}]})
    export default router
    
  3. 在main.js中挂载路由

    import Vue from 'vue'
    import App from './App.vue'
    // 引入vue-router组件库
    import VueRouter from 'vue-router'
    //引入路由配置文件
    import router from './router'Vue.config.productionTip = false
    // 使用插件
    Vue.use(VueRouter)
    new Vue({render: h => h(App),router, //挂载路由
    }).$mount('#app')
  4. 在App.vue中使用 router-link 和router-view标签 放路由的key和 路由的value

     <router-link class="list-group-item" active-class="active" to="/about">About</router-link><router-link class="list-group-item " active-class="active" to="/home">Home</router-link><!-- 显示路由内容的标签 --><router-view></router-view>
    
  5. 路由的注意事项

    1. 路由组件通常存放在pages文件夹,一般组件通常存放在components文件夹。
    2. 通过切换,“隐藏”了的路由组件,默认是被销毁掉的,需要的时候再去挂载。
    3. 每个组件都有自己的$route属性,里面存储着自己的路由信息。
    4. 整个应用只有一个router,可以通过组件的$router属性获取到。
      homeRoute===aboutRoute
      false
      homeRouter===aboutRouter
      true

    3.嵌套路由

    1. 配置路由规则,使用children配置项:

      routes:[{path:'/about',component:About,},{path:'/home',component:Home,children:[ //通过children配置子级路由{path:'news', //此处一定不要写:/newscomponent:News},{path:'message',//此处一定不要写:/messagecomponent:Message}]}
      ]
      
    2. 跳转(要写完整路径):

    <router-link to="/home/news">News</router-link>
    

    4.传递路由的query传参

    有两种query传参方式,分别是字符串传参和对象传参

    给detail传递参数

    <!-- 跳转并携带query参数,to的字符串写法 -->
    <router-link :to="/home/message/detail?id=666&title=你好">跳转</router-link><!-- 跳转并携带query参数,to的对象写法 -->
    <router-link :to="{path:'/home/message/detail',query:{id:666,title:'你好'}}"
    >跳转</router-link>
    

    在detail接受参数

    $route.query.id
    $route.query.title
    

    # 5.传递路由的params参数

    有两种params传参方式,分别是字符串传参和对象传参

    给Deatil组件传递参数

    第一步,在router.js的配置文件中声明参数的占位符

    {path:'/home',component:Home,children:[{path:'news',component:News},{component:Message,children:[{name:'xiangqing',path:'detail/:id/:title', //使用占位符声明接收params参数component:Detail}]}]
    }
    

    第二部,跳转并携带参数

     <!-- params传参的模板字符串写法 --><router-link :to="`/home/message/detail/${m.id}/${m.title}`">跳转{{m.title}}</router-link><!-- params传参的对象写法 --><!-- 跳转并携带params参数,to的对象写法 --><router-link:to="{name: 'xiangqing',//不能使用path配置params: {id: m.id,title: m.title,},}">跳转</router-link>
    

    第三步,接受使用参数

    $route.params.id
    $route.params.title
    

    特别注意,当使用params传参时,若使用to的对象写法,则不能使用path配置,只能使用name命名路由配置

    6.路由的props传参配置

    路由的props的出现是为了让路由组件能够更方便的接受参数

    props配置有三种写法,分别是对象,布尔值和函数写法

    {name:'xiangqing',path:'detail/:id',component:Detail,//第一种写法:props值为对象,该对象中所有的key-value的组合最终都会通过props传给Detail组件// props:{a:900}//第二种写法:props值为布尔值,布尔值为true,则把路由收到的所有params参数通过props传给Detail组件// props:true//第三种写法:props值为函数,该函数返回的对象中每一组key-value都会通过props传给Detail组件props(route){return {id:route.query.id,title:route.query.title}}
    }
    

    7.路由router-link标签的replace属性

    1. 作用:控制路由跳转时操作浏览器历史记录的模式
    2. 浏览器的历史记录有两种写入方式:分别为pushreplacepush是追加历史记录(入栈),replace是替换当前记录(先出栈顶元素,再入栈)。路由跳转时候默认为push
    3. 如何开启replace模式:<router-link replace .......>News</router-link>

    8.编程式路由导航

    不使用router-link标签进行路由跳转,而是使用$router提供的api进行跳转,push函数是入栈跳转,replace函数是替换跳转

    配置对象的写法与router-link to熟悉配置对象的写法一致

    //$router的两个API
    this.$router.push({name:'xiangqing',params:{id:xxx,title:xxx}
    })this.$router.replace({name:'xiangqing',params:{id:xxx,title:xxx}
    })
    this.$router.forward() //前进
    this.$router.back() //后退
    this.$router.go() //可前进也可后退 正数前进几步,负数后退几步
    

    9.缓存路由组件

    当一个路由组件A中出现输入类元素 ,比如文本框时,假如我们从A路由切换到B路由,因为路由切换实际上是销毁了路由组件,所以之后再重新切回A路由,A路由组件的文本框数据已经丢失了。所以我们要对A路由进行缓存,缓存的方式是使用keep-alive标签,包裹住A组件的显示区域,配合include属性使用

    include属性值是组件名,而不是命名路由的名字

    如果想要缓存多个路由组件,可写:include=['News','Message']   
    <keep-alive include="News"> <router-view></router-view>
    </keep-alive>
    
http://www.hrbkazy.com/news/10588.html

相关文章:

  • 网站语言那种好巨量引擎广告投放平台代理
  • 想在中国网站做海外代购镇江网站建设推广
  • 福建省华荣建设集团有限公司网站网络服务提供商是指
  • 网站大图轮播seo博客网址
  • 周口seo什么是seo标题优化
  • 专门做自助游的网站百度seoo优化软件
  • 建官网个人网站百度推广账号登录入口
  • 旅游网站的设计方案怎么做天猫seo搜索优化
  • 爱站网长尾关键词挖掘网站管理系统
  • 网站建设项目进展情况汇报外贸推广引流
  • 长沙企业网站建设品牌今日深圳新闻最新消息
  • 做个响应式网站多少钱阿里云免费域名
  • 云南公路建设市场网站企业建站用什么好
  • 立邦刷新服务多少钱一平米优化关键词排名软件
  • 仙居网站建设合肥关键词排名提升
  • 工业品企业网站源码收录网站排名
  • 怎样修改手机网站首页seo从0到1怎么做
  • 做公司网站 找谁做最常见企业网站公司有哪些
  • 哪有网站给光头强做面品牌推广活动方案
  • wordpress标签搜索优化教程网下载
  • 网站人员队伍建设落后云南网站建设百度
  • 网站系统建设方案西安危机公关公司
  • 免费空间注册网站网络营销理论基础
  • 淘宝客网站开发一个百度营销推广登录
  • 做商城网站买多大的空间成品网站1688入口的功能介绍
  • 制作网站注册页面模板网站制作策划
  • 好的策划方案网站免费seo技术教程
  • 域名备案查询网站备案信息查询十大经典营销案例
  • 人工智能网站开发建一个网站需要多少钱?
  • 有没有IT做兼职的网站线下推广公司