forked from PanJiaChen/vue-element-admin
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
perf[Tinymce]: dynamic import tinymce(PanJiaChen#2102)
- Loading branch information
1 parent
db1b5e9
commit 3031f6f
Showing
4 changed files
with
57 additions
and
16 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,39 @@ | ||
const dynamicLoadScript = (src, callback) => { | ||
const existingScript = document.getElementById(src) | ||
const cb = callback || function() {} | ||
|
||
if (!existingScript) { | ||
const script = document.createElement('script') | ||
script.src = src // src url for the third-party library being loaded. | ||
script.id = src | ||
document.body.appendChild(script) | ||
|
||
const onEnd = 'onload' in script ? stdOnEnd : ieOnEnd | ||
onEnd(script, cb) | ||
} | ||
|
||
if (existingScript && cb) cb(null, existingScript) | ||
|
||
function stdOnEnd(script, cb) { | ||
script.onload = function() { | ||
// this.onload = null here is necessary | ||
// because even IE9 works not like others | ||
this.onerror = this.onload = null | ||
cb(null, script) | ||
} | ||
script.onerror = function() { | ||
this.onerror = this.onload = null | ||
cb(new Error('Failed to load ' + src), script) | ||
} | ||
} | ||
|
||
function ieOnEnd(script, cb) { | ||
script.onreadystatechange = function() { | ||
if (this.readyState !== 'complete' && this.readyState !== 'loaded') return | ||
this.onreadystatechange = null | ||
cb(null, script) // there is no way to catch loading errors in IE8 | ||
} | ||
} | ||
} | ||
|
||
export default dynamicLoadScript |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -15,6 +15,10 @@ | |
import editorImage from './components/EditorImage' | ||
import plugins from './plugins' | ||
import toolbar from './toolbar' | ||
import load from './dynamicLoadScript' | ||
// why use this cdn, detail see https://github.com/PanJiaChen/tinymce-all-in-one | ||
const tinymceCDN = 'https://cdn.jsdelivr.net/npm/[email protected]/tinymce.min.js' | ||
export default { | ||
name: 'Tinymce', | ||
|
@@ -82,10 +86,12 @@ export default { | |
} | ||
}, | ||
mounted() { | ||
this.initTinymce() | ||
this.init() | ||
}, | ||
activated() { | ||
this.initTinymce() | ||
if (window.tinymce) { | ||
this.initTinymce() | ||
} | ||
}, | ||
deactivated() { | ||
this.destroyTinymce() | ||
|
@@ -94,6 +100,16 @@ export default { | |
this.destroyTinymce() | ||
}, | ||
methods: { | ||
init() { | ||
// dynamic load tinymce from cdn | ||
load(tinymceCDN, (err) => { | ||
if (err) { | ||
this.$message.error(err.message) | ||
return | ||
} | ||
this.initTinymce() | ||
}) | ||
}, | ||
initTinymce() { | ||
const _this = this | ||
window.tinymce.init({ | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -57,16 +57,6 @@ module.exports = { | |
} | ||
}, | ||
chainWebpack(config) { | ||
const cdn = { | ||
// inject tinymce into index.html | ||
// why use this cdn, detail see https://github.com/PanJiaChen/tinymce-all-in-one | ||
js: ['https://cdn.jsdelivr.net/npm/[email protected]/tinymce.min.js'] | ||
} | ||
config.plugin('html') | ||
.tap(args => { | ||
args[0].cdn = cdn | ||
return args | ||
}) | ||
config.plugins.delete('preload') // TODO: need test | ||
config.plugins.delete('prefetch') // TODO: need test | ||
|
||
|