Web前端 ---- 【Vue】什么?代码堆在一起不好维护?辛辛苦苦改造的单文件组件用不了?看我直接Vue Cli脚手架安排

news2024/11/29 12:38:48

目录

前言

单文件组件

什么是单文件组件

单文件组件的内容

Es6模块的导入和导出

创建单文件组件

Vue Cli脚手架



前言

继上篇文章Vue组件的使用介绍了如何使用Vue组件,但是发现有一个很重要的问题,就是代码复用性很差,并且无法提供样式,而这篇将介绍如何改造单文件组件以及Vue cli脚手架的使用

单文件组件

什么是单文件组件

  1. 一个文件对应一个组件
  2. 单文件组件的名字通常是:xxx.vue,这是Vue规定的,只有Vue框架能够认识,浏览器无法直接打开运行。需要Vue框架进行编译,将xxx.vue最终编译为浏览器能识别的html,js,css

单文件组件的内容

  1. 结构:<template>html代码</template>
  2. 交互:<script>js代码</script>
  3. 样式:<style>css代码</style>

<div class="app">
        <root></root>
    </div>
    <script>
        const x = {
            template:`
            <div>
                <h2>我是组件x</h2>
            </div>
            `
        }
        const y = {
            template:`
            <div>
                <h2>我是组件y</h2>
            </div>
            `
        }
        // 创建组件
        const root = {
            template:`
            <div>
                <h1>我是组件root</h1>
                <x></x>
                <y></y>
            </div>
            `,
            components:{x,y}
        }
        const vm= new Vue({
            el:'.app',
            components:{root}
        })
    </script>

由上代码可得知,无法给组件提供样式,接下来,我们在此代码基础上把组件改造为单文件组件

在改造前我们需要了解Es6模块开发中导出和导入

Es6模块的导入和导出

导出:

导出常量、变量、函数或类,只要在声明前加上export关键字即可

如果一个模块只导出一个值(该情况十分常见),此时可以使用 export default 来默认导出

导入:

导入其他模块导出的值需要使用import关键字

import 组件名 from 导入文件的路径

创建单文件组件

在上述原代码的基础上创建三个vue单文件组件

x组件

<template>
    <div>
        <h2>我是组件x</h2>
    </div>
</template>

<script>
export default {}
</script>

y组件

<template>
    <div>
        <h2>我是组件y</h2>
    </div>
</template>

<script>
export default {}
</script>

root组件

<template>
    <div>
        <h1>我是组件root</h1>
        <x></x>
        <y></y>
    </div>
</template>

<script>
// 导入
import x from './x.vue'
import y from './y.vue'
// 导出
export default {
    // 注册
    components:{x,y}
}
</script>

将Vue实例放在单独的js文件中

main.js

import root from './root'

new Vue({
    el:'.app',
    template:`
    <root></root>
    `,
    components:{root}
})

最后创建容器html页面

index.html

<div class="app"></div>
    <script src="../vue.js"></script>
    <script src="./main.js"></script>

需要将vue和main.js引入

辛辛苦苦改造组件为单文件组件,可以使用了吗?

结果是,没用。

该报错翻译过来就是不能在模块外使用import

那要如何使用呢?Vue Cli脚手架就可以解决

Vue Cli脚手架

关于Vue的脚手架如何安装,在这篇在Vuecli脚手架基础上自定义搭建项目中详细介绍了

直接找到src文件下的App.vue,将我们的根组件root.vue换上去,将components目录下的组件删除,将我们自己的组件换上去,注意import导入时的路径

在main.js中我们发现实例对象里面的配置项与我们略有不同

 我们的实例对象配置项

new Vue({
    el:'.app',
    
    components:{root}
})

脚手架中Vue实例的

new Vue({
  render: h => h(App),
}).$mount('#app')

el配置项和$mount是同理的,指定容器

其中的render函数是使用了箭头函数的用法

render普通函数

render(createElement){
    return createElement(App)
  }

之所以使用render函数是因为Vue脚手架用的是不完整的Vue.js文件,该文件是不包含编译模板字符串的,所以template就无法被编译。之所以使用不完整版的是因为编译模板字符串的文件包体积过大,且后期打包的时候也没用,所以为了体积更小所以舍弃,使用了render函数

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

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

相关文章

文件的写入和读取操作

题目&#xff1a; 编写一个程序&#xff0c;实现以下功能&#xff1a; 1. 创建一个新的文本文件&#xff0c;并将用户输入的数据写入文件中。 2. 打开已存在的文本文件&#xff0c;并将其中的数据显示在屏幕上。 #include <stdio.h> #include <stdlib.h> void wri…

事件委派+自定义属性+编程式导航实现路由跳转及传参

当我们页面中有许多a标签需要实现点击跳转到同一个页面并携带不同的参数时&#xff0c;我们就可以使用事件委派自定义属性编程式导航 的方式&#xff0c;用最小的内存实现路由跳转的最大效率。 为什么我们不用router-link 进行跳转&#xff1f; 要知道&#xff0c;我们页面中…

汇编:关于栈的知识

1.入栈和出栈指令 2. SS与SP 3. 入栈与出栈 3.1 执行push ax ↑↑ 3.2 执行pop ax ↓↓ 3.3 栈顶超界的问题 4. 寄存器赋值 基于8086CPU编程时&#xff0c;可以将一段内存当作栈来使用。一个栈段最大可以设为64KB&#xff08;0-FFFFH&#xff09;。 1.入栈和出栈指令…

058-第三代软件开发-文件Model

第三代软件开发-文件Model 文章目录 第三代软件开发-文件Model项目介绍文件Model 关键字&#xff1a; Qt、 Qml、 关键字3、 关键字4、 关键字5 项目介绍 欢迎来到我们的 QML & C 项目&#xff01;这个项目结合了 QML&#xff08;Qt Meta-Object Language&#xff09;…

[计算机网络]应用层概述

0.写在前面: 该层为教学模型的最后一层,某种意义上来说是最接近各位开发者的一层,正因如此,这层中的很多定义和概念大家都有属于自己的理解, 完全按照书本反而才是异类,因此在这里我会去结合我做前端开发的一些经验,来处理和讲解一些概念,另外本层中的部分协议也不会过多阐述了…

提升逼格,自己搭建博客网站不求人

背景 对于一个热爱分享知识和经验的大佬来说&#xff0c;搭建一个自己的个人博客是十分必要的。因为各个免费写博客平台都会有每天写博客限制&#xff0c;比如我现在这篇文章的限制&#xff0c;就是每天最多发表3篇&#xff0c;同时还给我的博客添加一大波广告&#xff0c;真是…

async函数和await关键字

async写在一个函数a前面&#xff0c;该函数变为异步函数&#xff0c;可在里面使用await关键字&#xff0c;await后面一般跟一个promise对象&#xff08;axios函数返回一个promise对象&#xff0c;里面有异步任务&#xff09;&#xff0c;await会原地等待该异步任务结果&#xf…

JVM基础篇:垃圾回收

1.前言 1.1C/C的内存管理 在C/C这类没有自动垃圾回收机制的语言中&#xff0c;一个对象如果不再使用&#xff0c;需要手动释放&#xff0c;否则就会出现内存泄漏。我们称这种释放对象的过程为垃圾回收&#xff0c;而需要程序员编写代码进行回收的方式为手动回收。内存泄漏指的…

WiFi 发射链路 MCS 自适应机制介绍

链路适配是指发射机选择最优的MCS向特定的接收机发送数据的过程。链路自适应算法的实现有其特殊性&#xff0c;但通常基于测量的数据包错误率(PER)。大多数算法监视PER并调整MCS以跟踪一个最佳的长期平均值&#xff0c;以平衡由于使用更高MCS发送更短数据包而减少的开销和由于更…

坚鹏:中国工商银行数字化背景下银行公司业务如何快速转型培训

中国工商银行作为全球最大的银行&#xff0c;资产规模超过40万亿元&#xff0c;最近几年围绕“数字生态、数字资产、数字技术、数字基建、数字基因”五维布局&#xff0c;深入推进数字化转型&#xff0c;加快形成体系化、生态化实施路径&#xff0c;促进科技与业务加速融合&…

jupyter notebook 添加conda环境变量为内核(kenel)

第一步&#xff1a;安装ipykernel 在激活环境后&#xff0c;需要安装ipykernel包&#xff0c;以便将Conda环境添加到Jupyter Notebook中。使用以下命令安装&#xff1a; pip install ipykernel第二步&#xff1a;将Conda环境添加到Jupyter 需要将Conda环境添加到Jupyter Not…

在拼多多,照见热气腾腾的平凡人生

文 | 螳螂观察 作者 | 易不二 内容丰富的《鲁迅日记》里&#xff0c;经常会出现“xx日晴&#xff0c;无事”的记载。 如果按照年份算&#xff0c;在被记载的日子里&#xff0c;每年鲁迅都有一二十天的时间是“无事”的状态。 很难想象&#xff0c;为人类历史文明前进照亮了…

2024年最新最全的Jmeter接口测试必会技能:jmeter对图片验证码的处理

jmeter对图片验证码的处理 在web端的登录接口经常会有图片验证码的输入&#xff0c;而且每次登录时图片验证码都是随机的&#xff1b;当通过jmeter做接口登录的时候要对图片验证码进行识别出图片中的字段&#xff0c;然后再登录接口中使用&#xff1b; 通过jmeter对图片验证码…

error LNK2038: 检测到“RuntimeLibrary”的不匹配项 解决方法

问题&#xff1a; 我们在使用Visual Studio编程的时候偶尔会遇到以下三种报错&#xff1a; error LNK2038: 检测到“RuntimeLibrary”的不匹配项: 值“MD_DynamicRelease”不匹配值“MDd_DynamicDebug” &#xff08;引用的是release模式&#xff0c;但设置成debug模式了…

知识点小总结

‘Integer(int)‘ 已经过时了 https://blog.csdn.net/qq_43116031/article/details/127793512 解决Java中的“找不到符号“错误 解决Java中的“找不到符号“错误_java: 找不到符号_很酷的站长的博客-CSDN博客 可右键打开 错误: 编码 UTF-8 的不可映射字符 错误: 编码 UTF-8 …

jQuery_06 过滤器的使用

什么是过滤器&#xff1f; 过滤器就是用来筛选dom对象的&#xff0c;过滤器是和选择器一起使用的。在选择了dom对象后在进行过滤筛选。 jQuery对象中存储的dom对象顺序与页面标签声明有关系。 声明顺序就是dom中存放的顺序 1.基本过滤器 使用dom对象在数组中的位置来作为过滤条…

FLASH 模拟 EEPROM 实验

STM32 本身没有自带 EEPROM&#xff0c;但是 STM32 具有 IAP&#xff08;在应用编程&#xff09;功能&#xff0c;所以我们可 以把它的 FLASH 当成 EEPROM 来使用。本章&#xff0c;我们将利用 STM32 内部的 FLASH 来实现NOR FLASH(EEPROM)(实验类似的效果&#xff0c;不过这次…

BigDecimal的使用全面总结

BigDecimal BigDecimal可以表示任意大小&#xff0c;任意精度的有符号十进制数。所以不用怕精度问题&#xff0c;也不用怕大小问题&#xff0c;放心使用就行了。就是要注意的是&#xff0c;使用的时候有一些注意点。还有就是要注意避免创建的时候存在精度问题&#xff0c;尤其…

【办公软件】电脑开机密码忘记了如何重置?

这个案例是家人的电脑&#xff0c;已经使用多年&#xff0c;又是有小孩操作过的&#xff0c;所以电脑密码根本不记得是什么了&#xff1f;那难道这台电脑就废了吗&#xff1f;需要重新装机吗&#xff1f;那里面的资料不是没有了&#xff1f; 为了解决以上问题&#xff0c;一般…

【深度学习】概率图模型(一)概率图模型理论简介

文章目录 一、概率图模型1. 联合概率表2. 条件独立性假设3. 三个基本问题 二、模型表示1. 有向图模型&#xff08;贝叶斯网络&#xff09;2. 无向图模型&#xff08;马尔可夫网络&#xff09; 三、学习四、推断 概率图模型&#xff08;Probabilistic Graphical Model&#xff0…