解決Vue控制臺(tái)報(bào)錯(cuò)Failed to mount component: template or render function not defined.
Vue控制臺(tái)報(bào)錯(cuò)Failed to mount component: template or render function not defined.
今天vue一直報(bào)錯(cuò)
vue.runtime.esm.js?2b0e:619 [Vue warn]: Failed to mount component: template or render function not defined.

一直以為是引用問(wèn)題,找了很多解決方案都沒(méi)有,到最后解決了記錄一下
我的這個(gè)問(wèn)題的根源在于 vue的文件命名和js的文件命名一致,然后又在同一個(gè)文件夾下面,比如下面

Area.vue 和 Area.js在同一個(gè)文件夾下面,且同名。
我的解決方案一
是將vue重命名為index.vue
解決方案二
再建一個(gè)文件夾專門(mén)放js文件,不和vue放在一個(gè)文件夾下面。
更改了文件命名后,能正常運(yùn)行了.
Vue控制臺(tái)報(bào)錯(cuò)信息收集并上報(bào)
自己理解為什么,直接上代碼
import axios from 'axios';
export default class JsReport {
private getToken;
private prefix: string;
constructor(prefix, getToken) {
console.log('js reporter init success');
this.getToken = getToken;
this.prefix = prefix;
}
/*
* 合并對(duì)象,將配置的參數(shù)也一并上報(bào)
*/
_cloneObj(oldObj) {
if (typeof(oldObj) != 'object') return oldObj;
if (oldObj == null) return oldObj;
var newObj = new Object();
for (var prop in oldObj)
newObj[prop] = oldObj[prop];
return newObj;
}
/**
* 擴(kuò)展對(duì)象
*/
_extendObj() {
var args = arguments;
if (args.length < 2) {return;}
var temp = this._cloneObj(args[0]); //調(diào)用復(fù)制對(duì)象方法
for (var n = 1,len=args.length; n <len; n++){
for (var index in args[n]) {
temp[index] = args[n][index];
}
}
return temp;
}
send(msg: string | Event, url: string, line: number, col: number, error: any) {
let defaults = {
errMsg: msg,
location: url,
lineNumber: line,
columnNumber: col,
errDetail: error,
}
if (error && error.stack) {
defaults.errDetail = error.stack.toString();
} else if (arguments.callee) {
let ext = [];
let fn = arguments.callee.caller;
let floor = 3;
while (fn && (--floor > 0)) {
ext.push(fn.toString());
if (fn == fn.caller) {
break;
}
fn = fn.caller;
}
defaults.errDetail = ext.join(",");
}
let headers = {
'Content-Type': 'application/json',
'Authorization': this.getToken
}
axios.put(
this.prefix + '/log/front/err/log',
defaults,
{ headers }
).then(res => {
if (res.status == 200 && res.data.code == 0) {
console.log('錯(cuò)誤上報(bào)成功');
}
}).catch(err => {
})
}
};
- 注冊(cè)
// apiConfig.baseUrl 為不同環(huán)境下的前綴,如果沒(méi)有,空即可
var jsReport = new JsReport(apiConfig.baseUrl, UserProfile.findLoginToken());
// window 的異常步獲被 vue 攔截處理掉了
Vue.config.errorHandler = function( err, vm, info) {
console.log('vue 步獲異常 err: ', err);
jsReport.send(err.message, window.location.href, 0, 0, err)
}
- 查看結(jié)果

總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
- vue項(xiàng)目引入百度地圖BMapGL鼠標(biāo)繪制和BMap輔助工具
- 解決Vue使用百度地圖BMapGL內(nèi)存泄漏問(wèn)題?Out?of?Memory
- vue中報(bào)錯(cuò)“error‘xxx‘?is?defined?but?never?used”問(wèn)題及解決
- Vue-cli3 $ is not defined錯(cuò)誤問(wèn)題及解決
- vue報(bào)錯(cuò)Cannot?read?properties?of?undefined?(...)類(lèi)型的解決辦法
- vue在data中定義變量后依舊報(bào)undefined的解決
- 完美解決vue引入BMapGL is not defined的問(wèn)題
相關(guān)文章
基于Vue CSR的微前端實(shí)現(xiàn)方案實(shí)踐
這篇文章主要介紹了基于Vue CSR的微前端實(shí)現(xiàn)方案實(shí)踐,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-05-05
vue語(yǔ)法自動(dòng)轉(zhuǎn)typescript(解放雙手)
這篇文章主要介紹了vue語(yǔ)法自動(dòng)轉(zhuǎn)typescript,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-09-09
Vue使用正則校驗(yàn)文本框?yàn)檎麛?shù)
這篇文章主要介紹了Vue使用正則校驗(yàn)文本框?yàn)檎麛?shù)問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-10-10
vue點(diǎn)擊Dashboard不同內(nèi)容 跳轉(zhuǎn)到同一表格的實(shí)例
這篇文章主要介紹了vue點(diǎn)擊Dashboard不同內(nèi)容 跳轉(zhuǎn)到同一表格的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-11-11
Vue3動(dòng)態(tài)倒計(jì)時(shí)的代碼實(shí)現(xiàn)
在使用Vue框架開(kāi)發(fā)Web應(yīng)用時(shí),倒計(jì)時(shí)功能是一個(gè)常見(jiàn)的需求,它可以在一定時(shí)間內(nèi)重復(fù)執(zhí)行某些操作,比如防止用戶重復(fù)提交表單、限制投票次數(shù)、實(shí)現(xiàn)驗(yàn)證碼獲取等功能,所以本文給大家介紹了Vue3動(dòng)態(tài)倒計(jì)時(shí)的代碼實(shí)現(xiàn),需要的朋友可以參考下2024-09-09
Vue2 模板template的四種寫(xiě)法總結(jié)
下面小編就為大家分享一篇Vue2 模板template的四種寫(xiě)法總結(jié),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-02-02

