vue入门介绍以及语法

一丶介绍

1.vue是什么

Vue (读音 /vjuː/,类似于 view) 是一套用于构建用户界面的渐进式框架。

Vue 的核心库只关注视图层,不仅易于上手,还便于与第三方库或既有项目整合。另一方面,当与现代化的工具链以及各种支持类库结合使用时,Vue 也完全能够为复杂的单页应用提供驱动。

官方网站:https://cn.vuejs.org

2、初始Vue.js

创建文件夹vue.js

创建demo.html

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
</head>

<body>
    <!-- id标识着Vue的作用范围 -->
  <div id=app>
      <!-- {{}}插值表达式,绑定vue中的data中的数据 -->
   {{message}}
  </div>

  <script src='vue.min.js'></script>
  <script>
      //创建一个vue
    new Vue({
         el: '#app',  //绑定vue的作用范围
         data:{ //定义页面中显示的模型数据
             message:'hello,vue!'
         }

     })
  
  
  </script>


</body>

</html>

这就是声明式渲染:Vue.js的核心是一个允许采用简洁的模板语法来声明式的将数据渲染进DOM的系统

这里的核心思想就是没有频繁的DOM操作,例如Jquery中,我们需要先找到div节点,获取到DOM对象,然后进行一系列的单点操作

二丶基本语法

1.基本数据渲染和指令

创建 01-基本数据渲染和指令.html

你看到的v-bind特性被称之为指令。指令带有前缀v-

除了使用插值表达式{{}}进行数据的渲染,也可以使用v-bind指令,它的简写的形式就是一个冒号(:)

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
</head>

<body>
    <!-- id标识着Vue的作用范围 -->
  <div id=app>
      <!-- {{}}插值表达式,绑定vue中的data中的数据 -->
    {{message}}
    <h1>一级标题</h1>
    <!-- 如果要将模型数据绑定到html属性中,则使用v-bind指令
    此时title中显示的是模型数据 -->
    <h1 v-bind:title="message">一级标题</h1>
    <!-- v-bind指令的简写形式是:冒号(:) -->
    <h1 :title="message">一级标题</h1>
  </div>

  <script src='vue.min.js'></script>
  <script>
      //创建一个vue
    new Vue({
         el: '#app',  //绑定vue的作用范围
         data:{ //定义页面中显示的模型数据
             message:'页面加载于' + new Date().toLocaleString()
         }

     })
  </script>
  
</body>

</html>

2.双向数据绑定

创建 02-双向数据绑定.html

双向数据绑定和单向数据绑定:使用 v-model 进行双向数据绑定

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
</head>

<body>
    <div id="app">
        <!-- v-bind:value只能进行单向数据绑定 -->
     <input type="text" v-bind:value="keyword">
        <!-- v-model:value可以进行双向数据绑定 -->
     <input type="text" v-model:value="keyword">
     <p>{{keyword}}</p>
    </div>
    <script src="vue.min.js"></script>
    <script>
        new Vue({
            el: '#app',
            data: {
               keyword:'你在世界的那个地方?' 
            }
        })
    </script>
</body>

</html>

3、事件

创建 03-事件.html

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
</head>

<body>
    <div id="app">
     <!-- v-on指令绑定事件,click指绑定事件的类型,事件发生时调用vue中的methods节点中定义的方法 -->
     <button v-on:click="search()">查询</button>
     <!-- 绑定事件指令可以使用@click来简写 -->
     <button @click="search()">查询2</button>
      <p>查询结构是:</p> <br>
      <!-- 加上:动态的去绑定 -->
      <a :href="result.site">{{result.name}}</a> <br>
       {{result.cite}} <br>
    </div>
    <script src="vue.min.js"></script>
    <script>
        new Vue({
            el: '#app',
            data: {
                result:{}
            },
            // 定义事件函数
            methods: {//可以在其中定义方法
                search:function(){
                    console.log('页面加载中.....')

                    this.result={
                        site:'http://www.baidu.com',
                        name: '百度',
                        cite: '[中国,哥伦比亚]'
                    }
                }
            }
        })
    </script>
</body>

</html>

三、路由

vue.js允许我们通过不同的url访问不同的内容。

通过 Vue.js 可以实现多视图的单页Web应用(single page web application,SPA)

需要我们在项目中引入路由的文件 vue-router.min.js

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
</head>

<body>
    <div id="app">
     <h1>Hello,app</h1>
     <p>
         <!-- `router-link` 默认会被渲染成一个 `a` 标签
              通过传入的 `to` 属性指定链接 -->
         <router-link to="/">首页</router-link>
         <router-link to="/student">会员管理</router-link>
         <router-link to="/teacher">讲师管理</router-link>
     </p>
     <!-- router-view 路由的出口
     路由匹配到的组件将渲染在这里面
    -->
     <router-view></router-view>
    </div>

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

    <script>
        //定义组件
        const Welcome={
            template:'<div>欢迎来到首页</div>'
        }
        const Student={
            template:'<div>会员等级列表</div>'
        }
        const Teacher={
            template:'<div>讲师列表</div>'
        }
        // 路由列表
        const routes=[
            {
            path: '/',redirect: '/welcome'//路由重定向
        },
        {
            path: '/welcome', component:Welcome 
        },
        {
            path: '/student',component:Student
        },
        {
            path:'/teacher',component:Teacher
        }
        ]

        // 路由对象:配置路由列表
        const router=new VueRouter({
            routes:routes   //定义路由列表
        })

        new Vue({
            el: '#app',
            data: {
                
            },
            router:router //将路由对象装置在Vue的上下文中
        })
    </script>
</body>

</html>

 

 

 

 

 

 
posted @ 2019-10-30 13:59  七月的风没有雨  阅读(381)  评论(0编辑  收藏  举报