zoukankan      html  css  js  c++  java
  • vue基础篇---路由的实现《2》

    现在我们来实现这样一个功能:

    一个页面,包含登录和注册,点击不同按钮,实现登录和注册页切换:

    编写父组件

    index.html

    <div id="app">
        <span>登录</span>
        <span>注册</span>
        <hr/>
        <div>
            登录页/注册页
        </div>
    </div>
    <script src="../node_modules/vue/dist/vue.js"></script>
    <script type="text/javascript">
        var vm = new Vue({
            el:"#app"
        })
    </script>

    编写登录组件

    编写组件,这里我们只写模板,不写功能:

    const loginForm = {
        template:'
        <div>
        <h2>登录页</h2> 
        用户名:<input type="text"><br/>
        密码:<input type="password"><br/>
        </div>
        '
    }

    编写注册组件

    新建单文件组件:register.js

    const registerForm = {
        template:'
        <div>
        <h2>注册页</h2> 
        用户名:<input type="text"><br/>
        密码:<input type="password"><br/>
        确认密码:<input type="password"><br/>
        </div>
        '
    }

    在父组件中引用

    在index.html中使用刚刚编写的两个组件

     <div id="app">
            <span>登录</span>
            <span>注册</span>
            <hr/>
            <div>
                <login-form></login-form>
                <register-form></register-form>
            </div>
        </div>
        <script src="../node_modules/vue/dist/vue.js"></script>
        <script src="js/login.js"></script>
        <script src="js/register.js"></script>
        <script type="text/javascript">
            var vm = new Vue({
                el:"#app",
                components:{// 引用登录和注册组件
                    loginForm,
                    registerForm
                }
            })
        </script>

    效果:

    问题

    我们期待的是,当点击登录或注册按钮,分别显示登录页或注册页,而不是一起显示。

    但是,如何才能动态加载组件,实现组件切换呢?

    虽然使用原生的Html5和JS也能实现,但是官方推荐我们使用vue-router模块。

    vue-router简介和安装

    使用npm安装:npm install vue-router --save

    在index.html中引入依赖:

    <script src="../node_modules/vue-router/dist/vue-router.js"></script>

    快速入门

    新建vue-router对象,并且指定路由规则:

    // 创建VueRouter对象
    const router = new VueRouter({
        routes:[ // 编写多个路由规则
            {
                path:"/login", // 请求路径
                component:loginForm // 组件名称
            },
            {path:"/register",component:registerForm},
        ]
    })
    • 创建VueRouter对象,并指定路由参数
    • routes:路由规则的数组,可以指定多个对象,每个对象是一条路由规则,包含以下属性:
      • path:路由的路径
      • component:组件名称 

    在父组件中引入router对象:

    var vm = new Vue({
        el:"#app",
        components:{// 引用登录和注册组件
            loginForm,
            registerForm
        },
        router // 引用上面定义的router对象
    })

    页面跳转控制:

    <div id="app">
        <!--router-link来指定跳转的路径-->
        <span><router-link to="/login">登录</router-link></span>
        <span><router-link to="/register">注册</router-link></span>
        <hr/>
        <div>
            <!--vue-router的锚点-->
            <router-view></router-view>
        </div>
    </div>
    • 通过<router-view>来指定一个锚点,当路由的路径匹配时,vue-router会自动把对应组件放到锚点位置进行渲染
    • 通过<router-link>指定一个跳转链接,当点击时,会触发vue-router的路由功能,路径中的hash值会随之改变  

    注意:单页应用中,页面的切换并不是页面的跳转。仅仅是地址最后的hash值变化。

    事实上,我们总共就一个HTML:index.html

  • 相关阅读:
    Hibernate4究竟怎么玩目录
    Hibernate检索策略之5.2多对一单向关联检索策略——Hibernate4究竟怎么玩
    Struts2 OGNL表达式中调用java静态方法无效的解决办法
    JDBC API中的execute返回值问题
    Hibernate检索策略之5.1类级别检索策略——Hibernate4究竟怎么玩
    PowerDesigner逆向工程mysql
    三种批量增加的性能分析
    Apache FtpServer的使用
    杭电1013
    杭电1008
  • 原文地址:https://www.cnblogs.com/coder-lzh/p/9745860.html
Copyright © 2011-2022 走看看