vue 报错总结


build后 页面空白
背景图片的引用
打包后样式缺失
scoped 应用
回到顶部
IE兼容
webpack 调试代码


build打包之后 页面空白:

一般情况下,通过webpack+vuecli默认打包的css、js等资源,路径都是绝对的。
但当部署到带有文件夹的项目中,这种绝对路径就会出现问题,
因为把配置的static文件夹当成了根路径,
那么要解决这种问题,就得引用相对路径。

解决办法

打开webpack.prod.conf.js

找到output增加 publicPath: './', 即可,如图。

image

vue 3.0 打包出现这个问题 需要在根目录添加 vue.config.js文件
添加如下配置即可

module.exports = {
    baseUrl: './'
}

背景图片的引用问题

webpack打包在会把图片转换成base64,在设置里面,limit超过10000就不会转换,不管事调大limit还是压缩图片都不能很好的满足需求。

上面虽然解决了资源路径的引用问题,但是资源里面的背景图片,
不像index.html中加载资源一样,通过./static/js/app.js引用可以正常加载,
背景图片资源是通过css加载的,
background: url("../../assets/images/logo-index.png") no-repeat;
被相对打包后变成了
url(static/img/logo-index.2f00bf2.png) no-repeat
所以我们要保留css引用图片的正常路径,即:
url``(../../``static``/img/logo-index.``2``f``00``bf``2``.png) ``no-repeat

添加如图所示的一行代码,这样不论是字体还是图片的引用问题都能解决。

image

来源https://www.cnblogs.com/moqiutao/p/7496718.html

打包后样式 缺失

需要package.json 修改 browserslist

  "browserslist": [
    "> 1%",
    "last 2 versions",
    "last 10 Chrome versions",
    "last 5 Firefox versions",
    "Safari >= 6",
    "not ie <= 8"
  ]

scoped 应用

scoped 可以将样式变为私有 但是有些样式 文件 不要加

  • 第三方库
  • 覆盖样式

回到顶部

相关DOM 绑定事件

methods:{
  goTop(){
      let currentScroll = document.documentElement.scrollTop || document.body.scrollTop;
         if (currentScroll > 2) {
            window.requestAnimationFrame(this.goTop);
             window.scrollTo (0,currentScroll - (currentScroll/5));
          }
   }
 }
// 为什么是  currentScroll > 2

IE 经过测试 最小是2 汗

IE打开 vue 项目 为空白页

原因是 有些第三方 组件 对 IE 支持不好
比如 swiper 是的 就是 swiper

另外 babel 默认的设置 转码为 env
但是有的 API 还是没有转
这就需要 引入 babel-polyfill
具体 内容 文档里 都有

  • 首先安装
npm install --save babel-polyfill
  • 入口文件引用
import "babel-polyfill";
  • webpack.config.js 文件修改入口 配置 (使用 vue-cli 2.x 的话 修改 webpack.base.conf.js)
entry: {
    //app: './src/main.js'
    app: ["babel-polyfill", "./src/main.js"]
  },

一般提示语法问题 都可以解决
注意:如果不能解决 八成就是 第三方库的问题

webpack 调试代码问题

一般 使用vue cli 工具
调试代码 你可能需要准确地知道错误来自于哪个源文件
但是 默认配置的报错信息 不能 定位到具体位置
经过查找 webpack文档
可以更改 webpack的 配置 webpack.config.js
(使用 vue-cli 2.x 的话 修改 webpack.dev.conf)

devtool: 'inline-source-map',

vue部署 nginx 路由路径 打开404

server {
        listen 8888;
        listen [::]:8888 default_server ipv6only=on;
        server_name xingkongs.club;
        root /root;
        index index.html index.htm;

        location / {
                try_files $uri $uri/ @router;
                index index.html;
        }
        location @router {
            rewrite ^.*$ /index.html last;
        }
}

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 1 Webpack 1.1 概念简介 1.1.1 WebPack是什么 1、一个打包工具 2、一个模块加载工具 3...
    Kevin_Junbaozi阅读 11,791评论 0 16
  • 第一部分 HTML&CSS整理答案 1. 什么是HTML5? 答:HTML5是最新的HTML标准。 注意:讲述HT...
    kismetajun阅读 28,415评论 1 45
  • 版权声明:本文为博主原创文章,未经博主允许不得转载。 webpack介绍和使用 一、webpack介绍 1、由来 ...
    it筱竹阅读 13,862评论 0 21
  • 携一卷唐诗远行,喜欢在乐府里高歌,在古风中低呤,和着琵琶声声,伴着箜篌峥峥,想象着缥缈中的那山,那水,那人...
    孤鸿故事家阅读 1,553评论 0 1
  • 底稿一开始很粗略,下笔很轻。勾画出大概轮廓后,再细致勾勒一遍,擦除多余的线条。 其实水彩画的铅笔底稿不该这么深,只...
    文朴阅读 6,435评论 14 32

友情链接更多精彩内容