本地非文字资源无法加载

目录

方法A.静态/动态绑定路径

方法B.require导入(运行时加载)

方法C.import导入(x)(编译时加载)

方法D.ref直接操作元素赋值(x)

相关知识

import和requir区别

模板路径:webpack和vue中路径@

视频,图片流,要么提前解析,要么require提前导入

原理:流式传输,边传输边处理,数据分包

方法A.静态/动态绑定路径

html 复制代码
<template>
  <div>
    <img src="../../assets/images/logo.png" />
  </div>
</template>

<template>
  <div>
    <img src="@/assets/images/logo.png" />
  </div>
</template>

方法B.require导入(运行时加载)

javascript 复制代码
const imgElements = this.$refs.uploadRef.$el.querySelectorAll('img');
    imgElements.forEach((imgElement: HTMLImageElement) => {
      imgElement.src = require('@/assets/img/excel.png');
    });

方法C.import导入(x)(编译时加载)

方法D.ref直接操作元素赋值(x)

运行时路径没有被正确解析,依旧是"@/assets/img/excel.png"

因为 JavaScript 中的相对路径是相对于当前执行脚本文件的路径,

而不是相对于 HTML 文件或项目根目录的路径,可以尝试重新编译

html 复制代码
<template>
  <img ref="myImage" />
</template>

<script>
export default {
  mounted() {
    this.$refs.myImage.src = "@/assets/img/excel.png";
  }
};
</script>

一般用绝对路径就没有问题,但模板路径的话,解析可能失败,

css 复制代码
::v-deep .mds-upload-card-icon {
  &::before {
    content: '';
    display: block;
    width: 31px;
    height: 31px;
    background: url('../../assets/img/excel.png');
    background-size: 31px 31px;
    z-index: 9999;
  }
}
//深度选择器::v-deep,改变第三方插件或者动态生成插件的样式
//在 CSS 中,& 符号用于引用父选择器.mds-upload-card-icon

相关知识

import和requir区别

javascript 复制代码
require/import

// CommonJS 的写法
const moduleA = require('moduleA');
const func1 = moduleA.func1;
const func2 = moduleA.func2;
// ES6 的写法
import { func1, func2 } from 'moduleA';

module.exports/export

// commonJS 的写法
var React = require('react');
var Breadcrumbs = React.createClass({
  render() {
    return <nav />;
  }
});
module.exports = Breadcrumbs;

// ES6 的写法
import React from 'react';
class Breadcrumbs extends React.Component {
  render() {
    return <nav />;
  }
};
export default Breadcrumbs;
  1. 规范 :require是CommonJS,AMD 规范的模块化语法,import是ECMAScript 6规范的模块化语法,如果要兼容浏览器的话必须转化成es5的语法;CommonJS模块默认export的是一个对象,即使导出的是基础数据类型
  2. 本质: require是赋值 过程,其实require 的结果就是对象、数字、字符串、函数等,再把require的结果赋值给某个变量,引入复杂数据类型时,数据浅拷贝 该对象。。import是解构过程。
  3. 加载 :require是运行 时加载,import是编译时加载;
  4. 位置 :require可以写在代码的任意 位置,import只能写在文件的最顶端且不可在条件语句或函数作用域中使用;
  5. 改变 :require通过module.exports 导出的不能再变,import通过export导出的值可以改变;

模板路径:webpack和vue中路径@

在Vue中,@符号通常用作别名,它是Vue CLI(Vue命令行工具)提供的一种特殊配置。

默认情况下,@别名 在Webpack中被配置为指向项目的src目录

XML 复制代码
tsconfig.json
{
  "compilerOptions": {
    "baseUrl": "",//baseUrl": "." 指定了项目的根路径,
    "paths": {
      "@/*": ["src/*"],//配置了 @ 别名指向 src 目录。
      // 其他路径映射...
    }
  }
}
相关推荐
布局呆星1 小时前
Vue Router :基础使用与嵌套路由实战
前端·javascript·vue.js
Gofarlic_oms16 小时前
利用API实现ANSYS许可证管理自动化集成
运维·服务器·开发语言·matlab·自动化·负载均衡
AI+程序员在路上7 小时前
VS Code 完全使用指南:下载、安装、核心功能与 内置AI 编程助手实战
开发语言·人工智能·windows·开源
小码哥_常7 小时前
安卓开发秘籍:解锁10大性能优化秘诀
前端
invicinble7 小时前
这里对java的知识体系做一个全域的介绍
java·开发语言·python
catchadmin7 小时前
使用 PHP TrueAsync 改造 Laravel 协程异步化的可行路径
开发语言·php·laravel
wbs_scy7 小时前
【Linux 线程进阶】进程 vs 线程资源划分 + 线程控制全详解
java·开发语言
AI人工智能+电脑小能手8 小时前
【大白话说Java面试题】【Java基础篇】第15题:JDK1.7中HashMap扩容为什么会发生死循环?如何解决
java·开发语言·数据结构·后端·面试·哈希算法
谁呛我名字8 小时前
JavaScript 类型转换与运算规则
javascript
try2find8 小时前
打印ascii码报错问题
java·linux·前端