67 lines
2.0 KiB
JavaScript
Raw Normal View History

2023-07-24 11:13:08 +08:00
import * as runtimeDom from '@vue/runtime-dom';
2023-09-06 09:51:55 +08:00
import { initCustomFormatter, registerRuntimeCompiler, warn } from '@vue/runtime-dom';
2023-07-24 11:13:08 +08:00
export * from '@vue/runtime-dom';
import { compile } from '@vue/compiler-dom';
import { isString, NOOP, extend, generateCodeFrame } from '@vue/shared';
function initDev() {
2023-09-06 09:51:55 +08:00
{
initCustomFormatter();
}
2023-07-24 11:13:08 +08:00
}
2023-09-06 09:51:55 +08:00
if (!!(process.env.NODE_ENV !== "production")) {
initDev();
2023-07-24 11:13:08 +08:00
}
2023-09-06 09:51:55 +08:00
const compileCache = /* @__PURE__ */ Object.create(null);
2023-07-24 11:13:08 +08:00
function compileToFunction(template, options) {
2023-09-06 09:51:55 +08:00
if (!isString(template)) {
if (template.nodeType) {
template = template.innerHTML;
} else {
!!(process.env.NODE_ENV !== "production") && warn(`invalid template option: `, template);
return NOOP;
2023-07-24 11:13:08 +08:00
}
2023-09-06 09:51:55 +08:00
}
const key = template;
const cached = compileCache[key];
if (cached) {
return cached;
}
if (template[0] === "#") {
const el = document.querySelector(template);
if (!!(process.env.NODE_ENV !== "production") && !el) {
warn(`Template element not found or is empty: ${template}`);
2023-07-24 11:13:08 +08:00
}
2023-09-06 09:51:55 +08:00
template = el ? el.innerHTML : ``;
}
const opts = extend(
{
hoistStatic: true,
onError: !!(process.env.NODE_ENV !== "production") ? onError : void 0,
onWarn: !!(process.env.NODE_ENV !== "production") ? (e) => onError(e, true) : NOOP
},
options
);
if (!opts.isCustomElement && typeof customElements !== "undefined") {
opts.isCustomElement = (tag) => !!customElements.get(tag);
}
const { code } = compile(template, opts);
function onError(err, asWarning = false) {
const message = asWarning ? err.message : `Template compilation error: ${err.message}`;
const codeFrame = err.loc && generateCodeFrame(
template,
err.loc.start.offset,
err.loc.end.offset
);
warn(codeFrame ? `${message}
${codeFrame}` : message);
}
const render = new Function("Vue", code)(runtimeDom);
render._rc = true;
return compileCache[key] = render;
2023-07-24 11:13:08 +08:00
}
registerRuntimeCompiler(compileToFunction);
export { compileToFunction as compile };