Vue语法(4)

news2025/1/10 14:30:27

目录

1. 自定义指令

1.1 使用方法

1.2 实际案例

1.3 全局指令和局部指令 

2. 组件对象

2.1 组件基础        

2.2 组件对象

2.3 组件的属性——props

2.4 全局组件和局部组件  

2.5 单文件组件

1. 概念:

2. 配置开发环境的指令:

3. 单文件组件中的使用说明


1. 自定义指令

1.1 使用方法

        在vue框架中除了它自带的指令(比如v-html v-text v-model v-if v-show等等)以外,还可以自己设计指令,通过自己设定的指令,来完成我们想要的功能。接下来就是一个v-jcm的自定义指令,用来实现更改字体颜色的功能。contenteditable是ES6提供的可编辑属性,默认为false,在页面中不可以输入,也就是不能编辑。

<div id="app">
    <div contenteditable="true" v-jcm="msg"></div>
</div>
directives: {
//在这里注册自定义指令
   jcm: {
         // data.value是上面v-jcm="msg"传进来的msg
         mounted(el, data) {
             el.innerHTML = `<font color="red">${data.value}</font>`
         }
    }
}

        如果没有设置这个自定义指令,div就没有内容。当设置了该指令时,在注册的时候设置了它将div的innerHTML设置成了红色字体的'hello'。需要通过挂载mounted来实现,其中的el表示使用该自定义指令的元素,data为v-jcm等号后面传进来的值。

        接下来展示一个将元素背景色更改的自定义指令——v-bgc

        <div v-bgc="a">red</div>
        <div v-bgc="b">blue</div>
directives: {
    bgc:{
        mounted(el,data){
            el.style.backgroundColor = data.value;
         }
     }
}

总结:自定义指令

 directives中注册(对象) ==> 挂载(mounted(el,data){ 操作代码})==> 元素中使用

1.2 实际案例

        实现的功能:自定义指令v-vip,是vip的盒子,右上角显示一个vip标识图。

// 样式,采用伪元素来放置vip图标
    <style>
        .box {
            width: 200px;
            height: 300px;
            background-color: aquamarine;
            border-radius: 10px;
        }
        .vip {
            position: relative;
        }
        .vip::after {
            content: "";
            position: absolute;
            display: block;
            width: 30px;
            height: 30px;
            background-image: url(./img/vip.png);
            /* 背景图片在盒子里平铺 */
            background-size: cover;
            right: 10px;
            top: 10px;
        }
    </style>

 vue模板中代码:使用了v-if/v-else来进行判断,如果是vip就执行v-vip指令。其中arr是app数据源中的arr数组:

arr: [ { id: 1, title: '标题一', count: 1, vip: true },

        { id: 2, title: '标题二', count: 5, vip: false },

        { id: 3, title: '标题三', count: 2, vip: true }]

        <template v-for="el in arr">
            <div v-if="el.vip" v-vip :key="el.id" class="box">
                <h1>{{el.title}}</h1>
                <p>数量:{{el.count}}</p>
            </div>
            <div v-else :key="el.id" class="box">
                <h1>{{el.title}}</h1>
                <p>数量:{{el.count}}</p>
            </div>
        </template>

 自定义指令代码:vip成员添加vip类名,通过类名来操作样式

directives: {
           vip: {
              mounted(el) {
                  el.classList.add('vip');
              }
          }
      },

结果:

1.3 全局指令和局部指令 

全局:所有元素(包括组件)都可以使用。语法:app.directive("vip",{钩子函数})

局部:只在当前组件的模板可以使用。语法:directives:{vip:{钩子},hqyj:{钩子}}

2. 组件对象

2.1 组件基础        

        组件是可复用的 Vue 实例,主要用于开发中,将具有相同特征但数据不同模块集为一个组件,减少代码的重复。需要把每一个组件写成一个文件,这样方便整理代码,代码逻辑、结构更加清晰。

        一个组件在使用前需要先注册:在app对象中的components中注册(对象形式),其中需要使用template对象来作为组件的使用模板。具体结构如下:

components:{
        组件名:{
              template:"模板内容"
            }
  }

2.2 组件对象

        引入组件的js文件在模板中使用组件步骤:script标签中引入(Vue框架的创建前)==>模板对象的components中注册==>模板中使用,案例如下:

<script type="module">
        import mynav from "./mynav.js";
        import mygoodsbox from "./mygoodsbox.js";
        import myfooter from "./myfooter.js";
        const app = {
            components: {
                mynav,
                mygoodsbox,
                myfooter,
            },
          };
        Vue.createApp(app).mount('#app');
</script>

使用:

<div id="app">
    <div class="top_bar">
        <mynav></mynav>
    </div>
    <div class="content">
        <mygoodsbox></mygoodsbox>
    </div>
    <div class="footer">
        <myfooter></myfooter>
    </div>
</div>

         下面给出其中一个组件的js文件(myfooter.js)作为参考,需要注意,引入的js文件中必须有template模板。

let myfooter = {
  template: `<div>尾部</div>`,
};
export default myfooter;

2.3 组件的属性——props

1. 声明属性:props:["属性名"]

简单使用:组件可以添加属性,当父组件结构相同,只有数据不同时,可以通过组件的属性来传不同的数据

        <box title="hello"></box>
components: {
    box: {
       data() { return {} },
       // 组件属性 是个数组 由上面<box title="hello"></box>传进来的 
       props: ["title"],
       // 当前组件的模板
       template: `<div>
                     <h3>box组件</h3>
                     <h3>{{title}}</h3>
                  </div>`
      }
}

2. 属性的类型验证

子组件内部注册组件的第二种方式。props:{属性名:验证机制}。其中的验证机制,可以是构造函数,可以是数组中放构造函数、自定义对象中的自定义函数,可以带默认值。

2.4 全局组件和局部组件  

全局组件:所有组件模板都可以使用。语法:app.component("组件名",{组件对象:成员,方法,数据源,声明钩子等等})

局部组件:在当前组建中注册的组件,只能在当前组件的模板中使用。语法:{components:{Box:{组件对象}},template:`使用Box组件`}

2.5 单文件组件

1. 概念:

        单文件组件是Vue.js框架中的一种组件文件格式。它将一个组件的HTML模板、JavaScript逻辑和CSS样式都封装在同一个.vue文件中,这样组件的代码就更加清晰,方便维护和复用。可以将前面的组件对象中的js文件变成vue文件,这个时候需要用到开发环境——利用vite。

2. 配置开发环境的指令:

初始化项目 cmd=>npm init vue@latest ==> 进入项目文件夹中npm i安装依赖包 ==> 运行程序npm run dev

3. 单文件组件中的使用说明

        a. 引入文件:@表示src目录

        b. 组件命名和使用:注册组件时可以使用大驼峰,使用时可以使用连字符、单标签、双标签

        c. 公认写法:例:index---i

                                组件的首字母大写,为了跟普通标签作区分

                                注册时组件名不能和HTML标签重名(可以通过加数字来区分)

        d. vue中的三个标签——template(必须要有)、script(可以没有)、style(可以没有)

问:为什么可以没有script标签呢?不是需要导出组件吗?

答:vite/webpack ===>vue-loader加载器,会把.vue文件中的代码转为js代码,默认会帮我们创建一个对象,然后把文件中的template模板写入这个对象的template属性中(所以template必须要有),并导出

注:vue2.0中只能有一个根标签;vue3.0可以有多个根节点

代码位置:因为入口文件是main.js,所以整个项目的代码都应该写在main.js所在文件夹中

总结写vue文件的步骤:script中在compotents中注册组件==> template标签中使用组件==>style标签中写组件的样式

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/644457.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

云迁移为业务赋能,跨出数字化转型第一步

新钛云服已累计为您分享752篇技术干货 云迁移如何赋能企业业务 随着科技的迅猛发展和数字化转型的浪潮席卷全球&#xff0c;越来越多的企业开始意识到云计算的重要性和潜力。在这个数字化时代&#xff0c;企业不再满足于传统的IT架构和数据中心&#xff0c;而是追求更高效、灵活…

《JAX可微分编程》包邮送书五本

文章目录 前言JAX到底是什么&#xff1f;书籍内容介绍包邮送书5本 前言 2015年&#xff0c;Google Brain开放了一个名为「TensorFlow」的研究项目&#xff0c;这款产品迅速流行并成为人工智能业界的主流深度学习框架&#xff0c;塑造了现代机器学习的生态系统。 7年后&#x…

Shell脚本文本三剑客之sed编辑器

目录 一、sed编辑器简介 二、sed工作流程 三、sed命令 四、sed命令的使用 1.sed打印文件内容&#xff08;p&#xff09; &#xff08;1&#xff09;打印文件所有行 &#xff08;2&#xff09;打印文件指定行 2.sed增加、插入、替换行&#xff08;a、i、c&#xff09; …

CVPR 2023 | 视频AIGC,预测/插帧/生成/编辑

1、A Dynamic Multi-Scale Voxel Flow Network for Video Prediction 视频预测&#xff08;video prediction&#xff09;的性能已经通过先进的深度神经网络大幅提高。然而&#xff0c;大多数当前的方法存在着大的模型尺寸和需要额外的输入&#xff08;如&#xff0c;语义/深度…

【Instruction Tuning】ChatGLM 微调实战(附源码)

在之前的文章中&#xff0c;我们已经讲过了 ChatGPT 的三个主要流程&#xff1a; SFT&#xff1a;通过 Instruction Tuning 来微调一个监督学习模型。Reward Model&#xff1a;通过排序序列来训练一个打分模型。Reinforcement Learning&#xff1a;通过强化学习来进一步优化模…

【MySQL新手入门系列一】:手把手教你入门MySQL

如果您是一位刚刚开始学习MySQL的新手&#xff0c;本文将为您提供一些实用的入门知识和技巧&#xff0c;帮助您快速上手。 本篇文章将以windows为例&#xff0c;介绍MySQL的基础知识&#xff0c;以及如何安装、卸载、配置和使用它。 导读 一、概览1.1 MySQL是什么1.2 为什么要学…

一文掌握linux网络相关命令

欢迎关注博主 Mindtechnist 或加入【Linux C/C/Python社区】一起学习和分享Linux、C、C、Python、Matlab&#xff0c;机器人运动控制、多机器人协作&#xff0c;智能优化算法&#xff0c;滤波估计、多传感器信息融合&#xff0c;机器学习&#xff0c;人工智能等相关领域的知识和…

阿里企业邮箱登录入口

阿里企业邮箱登录入口&#xff1a;https://qiye.aliyun.com/ 阿里企业邮箱可以使用邮箱账号登录&#xff0c;也可以使用钉钉账号登录&#xff0c;打开登录入口&#xff0c;如下图&#xff1a; 阿里企业邮箱登录入口 企业邮箱购买页面&#xff1a;aliyunbaike.com/go/mail免费企…

归并排序和快速排序(C++)

归并排序是一种经典的排序算法&#xff0c;也被称为“归并算法”。它的基本思想是将待排序数组分成若干个子数组&#xff0c;每个子数组都是有序的&#xff0c;然后将这些子数组合并成一个大的有序数组。 具体实现过程如下&#xff1a; 将待排序数组不断划分为左右两个子数组&…

IMX6ULL裸机篇之SPI实验-SPI主控代码实现

一. SPI 实验 SPI实验&#xff1a;学习如何使用 I.MX6U 的 SPI 接口来驱动 ICM-20608&#xff0c;读取 ICM-20608 的六轴数据。 本文学习 SPI主控芯片的代码编写。其中&#xff0c;包括SPI工作模式设置&#xff0c;主从模式设置&#xff0c;时钟配置等实现。 二. SPI 主控芯…

光学介质材料——光学膜

手机、平板、智能电视等设备之所以能够发光发亮离不开一个重要的组成材料——光学膜。那光学膜是什么回事呢&#xff1f; 光学膜是指在光学元件或独立基板上&#xff0c;制镀或涂布一层或多层介电质膜或金属膜或这两类膜的组合&#xff0c;以改变光波的传递特性&#xff0c;包…

MySQL索引:让你的数据库查询快到起飞!

&#x1f495;世界上最美好的东西之一&#xff0c;就是你每天都有机会开始全新的一天。&#x1f495; &#x1f43c;作者&#xff1a;不能再留遗憾了&#x1f43c; &#x1f386;专栏&#xff1a;MySQL学习&#x1f386; &#x1f697;本文章主要内容&#xff1a;详细介绍如何查…

SSD、内存和 L1 Cache 相比速度差多少倍

一道面试题&#xff1a;SSD、内存和 L1 Cache 相比速度差多少倍&#xff1f; 其实比起复杂的技术问题&#xff0c;我更喜欢在面试中提问这种像生活常识一样的简单问题。因为我觉得&#xff0c;复杂的问题是由简单的问题组成的&#xff0c;如果你把简单的问题学扎实了&#xff…

自动化运维工具—Ansible

一、Ansible概述 1.1 Ansible是什么 Ansible是一个基于Python开发的配置管理和应用部署工具&#xff0c;现在也在自动化管理领域大放异彩。它融合了众多老牌运维工具的优点&#xff0c;Pubbet和Saltstack能实现的功能&#xff0c;Ansible基本上都可以实现。 Ansible能批量配…

面试问题总结---嵌入式部分和项目部分

1、本栏用来记录社招找工作过程中的内容,包括基础知识学习以及面试问题的记录等,以便于后续个人回顾学习; 暂时只有2023年3月份,第一次社招找工作的过程; 2、个人经历: 研究生期间课题是SLAM在无人机上的应用,有接触SLAM、Linux、ROS、C/C++、DJI OSDK等; 3、参加工作后…

面试问题总结----ROS部分

1、本栏用来记录社招找工作过程中的内容,包括基础知识学习以及面试问题的记录等,以便于后续个人回顾学习; 暂时只有2023年3月份,第一次社招找工作的过程; 2、个人经历: 研究生期间课题是SLAM在无人机上的应用,有接触SLAM、Linux、ROS、C/C++、DJI OSDK等; 3、参加工作后…

Python3.9使用最新版pyinstaller将项目或程序打包成exe或者mac中的可执行文件

1、pyinstaller的说明&#xff1a; pyinstaller 能够在 Windows、Linux、Mac 等操作系统下将 Python 源文件打包&#xff0c;通过对源文件打包&#xff0c; Python 程序可以在没有安装 Python 的环境中运行&#xff0c;也可以作为一个独立文件方便传递和管理。 PyInstaller 支…

NLP-基于bertopic工具的新闻文本分析与挖掘

NLP-基于bertopic工具的新闻文本分析与挖掘 一&#xff0c;前言 最近简单接触了一些NLP的内容&#xff0c;练一下如何结合ChatGPT进行学习。 二&#xff0c;具体过程 &#xff08;1&#xff09;预处理文本&#xff0c;记录处理过程。 在使用Bertopic进行主题建模之前&…

【数据库一】MySQL数据库初体验

MySQL数据库初体验 1.数据库基本概念1.1 数据Data1.2 表1.3 数据库1.4 数据库管理系统1.5 数据库系统 2.数据库的发展3.主流的数据库介绍3.1 SQL Server&#xff08;微软公司产品&#xff09;3.2 Oracle &#xff08;甲骨文公司产品&#xff09;3.3 DB2&#xff08;IBM公司产品…

MySQL-索引详解(五)

♥️作者&#xff1a;小刘在C站 ♥️个人主页&#xff1a; 小刘主页 ♥️努力不一定有回报&#xff0c;但一定会有收获加油&#xff01;一起努力&#xff0c;共赴美好人生&#xff01; ♥️学习两年总结出的运维经验&#xff0c;以及思科模拟器全套网络实验教程。专栏&#xf…