85.【Vue-细刷-01】(五)

简介: 85.【Vue-细刷-01】
  • 调用方式: 对象.属性1.属性2()
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <div>
        <button onclick="obj3.a7.a8()">点击我调用方法5</button>
    </div>
    <script type="text/javascript">
        // 第五种 对象里面包含对象(内嵌方法)  
        var obj3 = {
            a7:{
                a8: function a9() {
                console.log(5)
            }
            }
        }
    </script>
</body>
</html>

第六种: var 函数名=(参数)=>{},调用方式: 函数名()

  • 调用方式: 函数名()
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <div>
        <button onclick="obj4()">点击我调用方法6</button>
    </div>
    <script type="text/javascript">
        // 第六种:箭头函数
        var obj4=()=>{
            console.log(6);
        }
    </script>
</body>
</html>

第七种:var 对象={属性名(){}}。调用方式: 对象.属性名()

  • 可以省略 :function
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <div>
        <button onclick="a()">点击我调用方法1</button>
        <button onclick="a2()">点击我调用方法2</button>
        <button onclick="obj.a3()">点击我调用方法3</button>
        <button onclick="obj2.a5()">点击我调用方法4</button>
        <button onclick="obj3.a7.a8()">点击我调用方法5</button>
        <button onclick="obj4()">点击我调用方法6</button>
        <button onclick="obj5.a10()">点击我调用方法7</button>
    </div>
    <script type="text/javascript">
        // 第一种 属性名
        a1: function a() {
            console.log(1)
        }
        // 第二种 普通方法
        function a2() {
            console.log(2)
        }
        // 第三种 对象里面的属性是方法 无函数名
        var obj = {
            a3: function a4() {
                console.log(3)
            }
        }
        // 第四种 对象里面的属性是方法 有函数名
        var obj2 = {
            a5: function a6() {
                console.log(4)
            }
        }
        // 第五种 对象里面包含对象(内嵌方法)  
        var obj3 = {
            a7:{
                a8: function a9() {
                console.log(5)
            }
            }
        }
        // 第六种 :箭头函数
        var obj4=()=>{
            console.log(6);
        }
        var obj5={
            a10(){
                console.log(7)
            }
        }
    </script>
</body>
</html>

5.data的两种方法(对象和方法)⭐

第一种:利用对象的写法进行存储 (常用写法)

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src="../js/vue.js"></script>
</head>
<body>
    <div id="root">
        <h1>{{message}}</h1>
    </div>
<script>
    // 第一种利用对象的方式进行存储。
    new Vue({
        el:'#root',
        data:{
            message:'你好,吉士先生'
        }
    });
</script>
</body>
</html>

第二种: 利用方法的写法进行存储 返回的是对象

  • 方法返回的数据是对象
  • 可以简写为 data(){return {} } 省略function
  • 方法不要使用箭头函数,否则会导致this转变成window
  • 组件中用的多
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src="../js/vue.js"></script>
</head>
<body>
    <div id="root">
        <h1>{{message}}</h1>
    </div>
<script>
    // 第一种利用对象的方式进行存储。
    /*
    new Vue({
        el:'#root',
        data:{
            message:'你好,吉士先生'
        }
    });
    */
    //第二种利用函数的方式进行存储,返回值是 对象
    new Vue({
        el:'#root',
        data:function(){  //可以简写为 data(){return {} }.data尽量不要使用箭头函数,我们要使用普通函数。否则this指向的是window,而不是Vue
            return{
                message:'你好,吉士先生'
            }
        }
    });
</script>
</body>
</html>

(七)、Vue中的数据代理(_date)

1.数据代理模式基本介绍

  1. 我们首先在data的对象中传入数据
  2. 然后再_data中进行收集数据
  3. 再然后_data寻找代理vm,vm帮助我们进行代理数据
  4. 最重要的一点是: 代理对象不仅拥有读取的功能,也有更改的功能。

2.查看数据核实信息

发现数据引用的数据是true

console.log(vm.name===vm._data.name)   true
• 1
![<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src="../js/vue.js"></script>
</head>
<body>
    <!-- 准备一个容器 -->
    <div id="root">
        <h2>学校名字: {{name}}</h2>
        <h2>学校地址: {{address}}</h2>
        <h2>学科: {{subject}}</h2>
    </div>
    <!-- 进行配置Vue的实列 -->
    <script type="text/javascript">
        var vm=new Vue({
            el:'#root',
            data:{
                name:'长春工业大学',
                address:'福祉大路',
                subject:'软件工程'
            }
        });
        console.log(vm.name===vm._data.name)
    </script>
</body>
</html>

相关文章
|
2天前
|
缓存 JavaScript 前端开发
《基础篇第4章:vue2基础》:使用vue脚手架创建项目
《基础篇第4章:vue2基础》:使用vue脚手架创建项目
11 3
|
4天前
|
JavaScript 前端开发 开发者
Vue v-for 进阶指南:in 与 of 的区别及应用场景 | 笔记
Vue.js 中的 v-for 是强大的遍历指令,但其中的 in 和 of 关键字往往被开发者忽视。尽管它们的用法相似,但适用的场景和数据结构却各有不同。本文将详细探讨 v-for 中 in 和 of 的区别、适用场景以及在实际开发中的最佳使用时机。通过理解它们的差异,你将能够编写更加高效、简洁的 Vue.js 代码,灵活应对各种数据结构的遍历需求。
40 6
|
2天前
|
缓存 JavaScript
Vue 中 computed 与 method 的区别
【10月更文挑战第15天】computed 和 method 是 Vue 中两个重要的选项,它们在功能和特点上存在着明显的区别。理解并合理运用它们的区别,可以帮助我们构建更高效、更具可维护性的 Vue 应用。在实际开发中,要根据具体情况灵活选择使用,以满足不同的需求。
5 2
|
2天前
|
JavaScript 搜索推荐 UED
vue的自定义指令
【10月更文挑战第14天】Vue 自定义指令为我们提供了一种强大的工具,使我们能够更灵活地控制和扩展 Vue 应用的行为。通过合理地使用自定义指令,可以提高开发效率,增强应用的功能和用户体验。
|
3天前
|
JavaScript
|
5天前
|
缓存 JavaScript 前端开发
Vue 中动态导入的注意事项
【10月更文挑战第12天】 在 Vue 项目中,动态导入是一种常用的按需加载模块的技术,可以提升应用性能和效率。本文详细探讨了动态导入的基本原理及注意事项,包括模块路径的正确性、依赖关系、加载时机、错误处理、缓存问题和兼容性等,并通过具体案例分析和解决方案,帮助开发者更好地应用动态导入技术。
|
5天前
|
JavaScript API
vue 批量自动引入并注册组件或路由等等
【10月更文挑战第12天】 vue 批量自动引入并注册组件或路由等等
|
5天前
|
JavaScript 算法 前端开发
深入剖析Vue中v-for的使用及index作为key的弊端
深入剖析Vue中v-for的使用及index作为key的弊端
14 2
|
4天前
|
JavaScript UED
Vue + ElementUI 实现动态添加和删除表单项的多层嵌套表单
【10月更文挑战第5天】本示例展示了如何在 Vue.js 中使用 Element UI 组件实现动态添加和删除嵌套表单项。该表单包含设备信息、设备部位及其对应的任务列表,支持用户动态添加设备部位和任务,并提供相应的表单验证规则。
24 0
Vue + ElementUI 实现动态添加和删除表单项的多层嵌套表单
|
5天前
|
JavaScript
《进阶篇第9章》学习vuex知识点后练习:求和案例_纯vue版代码
《进阶篇第9章》学习vuex知识点后练习:求和案例_纯vue版代码
11 1