vue2.0和vue3.0获取当前文件夹下的所有vue文件区别

文章目录

vue2.0

  1. 在Vue 2.0项目中,要获取当前文件夹下的所有.vue文件,你可以使用Node.js的文件系统模块(fs)和路径模块(path)来实现。以下是一个简单的示例,演示如何列出特定文件夹下的所有.vue文件:

    cpp 复制代码
    const path = require('path');
    const files = require.context('./', false, /\.vue$/);
    console.log(path, files, 'filesfiles');
    const modules = {};
    files.keys().forEach((key) => {
      const name = path.basename(key, '.vue');
      modules[name] = files(key).default || files(key);
    });
    export default modules;
  2. 组件在其他地方中的应用

    cpp 复制代码
    // 加入element为获取的组件
    let element = {
    	beforeCreate: Array(1),
    	beforeDestroy: Array(1),
    	cname: "导航组",
    	computed: Object,
    	configName: "c_home_menu",
    	data: ƒ data(),
    	defaultName: "menus",
    	icon: "icondaohangzu1",
    	methods: Object,
    	mounted: ƒ mounted(),
    	name: "home_menu",
    	num: 1718182717610000,
    	props: Object,
    	render: ƒ render(),
    	staticRenderFns: Array(0),
    	type: 0,
    	watch: Object,
    	__file: "src/components/mobilePageDiy/home_menu.vue",
    	_compiled: true,
    	_scopeId: "data-v-ff5d6a5a",
    }
    // 获取data中定义的变量
    console.log(element.data().defaultConfig) 
    // 获取methods中的方法,并执行
    console.log(data.element.methods)

vue3.0

  1. 在Vue 3中,你可以使用Vite作为构建工具来获取当前文件夹下的所有.vue文件。以下是一个简单的示例,展示如何使用import.meta.glob函数来实现这一点:
    import.meta.globEager 是 Vue3 中新增加的一个 API,用于在编译时期即加载所有的模块。相比较于 import 和 require,import.meta.globEager 是一种更加高效的加载方式。
    使用import.meta.globEager批量导入文件,第一次进入很慢(created断点都需要几秒才能进入)
    解决方法:使用import.meta.glob+defineAsyncComponent异步批量导入(秒进created的断点)

    cpp 复制代码
    // 在Vue组件中使用import.meta.glob
    <script setup>
    import { defineAsyncComponent } from 'vue';
    // 使用import.meta.glob来匹配当前目录下所有的.vue文件
    const vueFiles = import.meta.glob('./*.vue');
    // 如果你想获取文件列表,而不是模块对象,可以使用下面的代码
    // const vueFilePaths = Object.keys(vueFiles);
    const components = import.meta.globEager('./components/*.vue');
    console.log(modules, components);
    const obj = {};
    Object.keys(modules).forEach((key: string) => {
      const viewSrc = components[key];
      const file = viewSrc.default;
      const name = file.name;
      obj[name] = defineAsyncComponent(file);
    });
    export default obj;
    </script>


    2. 在组件中的运用

    cpp 复制代码
    let element = {
    	components: {CBgColor: {...}, CCascader: {...}, CFoot: {...}, CGoods: {...}, CHotWord: {...}, ...},
    	componentsName: "auxiliary_box",
    	name: "CAuxiliaryBox",
    	props: {activeIndex: {...}, num: {...}, index: {...}},
    	render: ƒ _sfc_render(_ctx, _cache, $props, $setup, $data, $options),
    	setup: setup(props) { const store = mobildConfigModalStore(); let configObj = ref({}); let rCom = ref([]); onMounted(() => {...},
    	__file: "D:/weibao/wb-saas-web/src/views/ecommerce/system/homeDecoration/mobileConfigDiyStyle/c_auxiliary_box.vue",
    	__hmrId: "78eea2c2",
    }
    // 调用组件中setUp方法中return出来的数据
    const useXxx = data.element.setup;
    // 若使用了props需要进行传参
    const dataP = useXxx({ num: towD.num });
    properties = dataP.defaultConfig.value;

当前文件夹下的所有vue文件区别

在Vue 2.x和Vue 3.x中获取当前文件夹下所有.vue文件的差异通常不是由Vue框架本身直接支持的,而是由构建工具(如Webpack或Vite)处理的

相关推荐
BigYe程普8 分钟前
我开发了一个出海全栈SaaS工具,还写了一套全栈开发教程
开发语言·前端·chrome·chatgpt·reactjs·个人开发
神之王楠20 分钟前
如何通过js加载css和html
javascript·css·html
余生H25 分钟前
前端的全栈混合之路Meteor篇:关于前后端分离及与各框架的对比
前端·javascript·node.js·全栈
花花鱼25 分钟前
@antv/x6 导出图片下载,或者导出图片为base64由后端去处理。
vue.js
程序员-珍28 分钟前
使用openapi生成前端请求文件报错 ‘Token “Integer“ does not exist.‘
java·前端·spring boot·后端·restful·个人开发
axihaihai32 分钟前
网站开发的发展(后端路由/前后端分离/前端路由)
前端
流烟默44 分钟前
Vue中watch监听属性的一些应用总结
前端·javascript·vue.js·watch
2401_857297911 小时前
招联金融2025校招内推
java·前端·算法·金融·求职招聘
茶卡盐佑星_1 小时前
meta标签作用/SEO优化
前端·javascript·html
与衫1 小时前
掌握嵌套子查询:复杂 SQL 中 * 列的准确表列关系
android·javascript·sql