使用vue-router,vue-resource,VUX简单案例

创建四个基本的组件

Home.vue
<template>
  <div id="home" class="home-box">
   首页
  <button @click="goNews()">通过js点击跳转到新闻页</button>

  </div>

</template>



<script>
  
  export default {
    data(){
      return{
          msg:"首页组件",
          name:"父子组件传值---值在父亲这边定义的",
          name2:"父组件的title",
          goodsList:[]
      }
    },
    methods:{

         goNews(){

           this.$router.push({path:"news"})

         }


    },
    components:{

    },
    mounted(){

    }


  }



</script>

<style lang="scss" scoped>

  .list{

    li{
      height:3.4rem;

      line-height:3.4rem;

      boder-bottom:1px solid #eee;

      font-size:1.6rem;

      a{

        color:#666;


      }
    }
  }

</style>
News.vue

<template>
    <div>
      <h2>新闻列表组件</h2>
      <ul>
        <li v-for="item in goodsList">
          <router-link :to="'/gContent?id='+item.aid">
            {{item.title}}
          </router-link>
        </li>
      </ul>
    </div>
</template>

<script>



    export default {
      data(){

        return{
              msg:"父组件的msg",
          goodsList:[
              ]
        }
      },
      components:{

      },
      methods:{

        RequestData(){

          var api = "http://www.phonegap100.com/appapi.php?a=getPortalList&catid=20&page=1"
          this.$http.jsonp(api).then((response)=>{

            this.goodsList = response.body.result
          },(err)=>{
            console.log(err);
          })

        }

      },
      mounted(){
        this.RequestData();
      }
    }
</script>

<style lang="scss" scoped>

</style>
APP.vue

<template>
  <div id="app">
    <header >

      <router-link to="/home">首页</router-link>
      <router-link to="/news">新闻页</router-link>
      <router-link to="/user">用户</router-link>

    </header>
    <div  class="vue-Router" >
      <router-view></router-view>
    </div>
  </div>
</template>
mian.js

import Vue from 'vue'
import App from './App.vue'
import VueResource from 'vue-resource'
import VueRouter from  'vue-router'

//1.引入并 Vue.use(VueRouter)   (main.js)
Vue.use(VueResource);
Vue.use(VueRouter);

//2.配置路由 创建组件 引入组件 定义路由  (建议复制s)

import home from './components/Home.vue';
import news from './components/News.vue';
import user from './components/User.vue';
import gContent from './components/Gcontent.vue';

  import addUser from  './components/User/addUser.vue';
  import listUser from  './components/User/listUser.vue';

const routes = [
  { path: '/home', component: home },
  { path: '/news', component: news },
/*  { path: '/content/:id',component:content},*/  /* 用/:id 的方法传值,获取用this.$route.params*/
  { path: '/gContent',component:gContent},  /* 用/?id=123 的方法传值,获取用this.$route.query*/
  /*{ path: '*', redirect: '/home' },*/
  //路由的嵌套,先配置父路由,/user ,再配置子路由的属性  最后<router-link to="/user/userlist"></router-link>
  {
    path:'/user',component:user,
    children:[
      {
        path: 'useradd', component: addUser
      },
      {
        path: 'userlist', component: listUser

      }
    ]


  }

  /*  默认跳转路由*/
];

//3.实例化VueRouter
const router = new VueRouter({
  mode: 'history', //hash模式改为history模式 可以使访问的url不同
  routes // (缩写)相当于 routes: routes
});

new Vue({
  el: '#app',
  router,
  render: h => h(App)
});

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue中,使用vue-router进行路由管理是非常方便的。在静态页面中也可以使用vue-router,只需要在静态页面中引入vue.js和vue-router.js,并按照vue-router使用方法进行配置即可。 下面是一个使用vue-router的静态页面示例: 1. 在静态页面中引入vue.js和vue-router.js: ```html <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Vue Router Static Page</title> <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script> <script src="https://cdn.jsdelivr.net/npm/vue-router/dist/vue-router.js"></script> </head> <body> <div id="app"> <router-view></router-view> </div> </body> </html> ``` 2. 在静态页面中配置路由: ```js const Foo = { template: '<div>foo</div>' } const Bar = { template: '<div>bar</div>' } const router = new VueRouter({ routes: [ { path: '/foo', component: Foo }, { path: '/bar', component: Bar } ] }) const app = new Vue({ router }).$mount('#app') ``` 在上面的代码中,我们首先定义了两个组件`Foo`和`Bar`,然后配置了路由对象`router`,将`Foo`和`Bar`组件分别映射到了`/foo`和`/bar`路径上。最后,我们创建了一个Vue实例,并将`router`对象作为参数传递给Vue实例的`router`选项中,这样就完成了vue-router的配置。 通过上述配置,我们就可以在静态页面中使用vue-router进行路由管理了。当用户访问`/foo`路径时,页面会显示`Foo`组件中的内容,访问`/bar`路径时,页面会显示`Bar`组件中的内容。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值