_createElement() — vue Function Reference
Architecture documentation for the _createElement() function in create-element.ts from the vue codebase.
Entity Profile
Dependency Diagram
graph TD 7052be7e_b5c9_7a95_ee8a_73a3c05abcb2["_createElement()"] 642a6516_0239_a923_4b9f_35cbc2fdb666["createElement()"] 642a6516_0239_a923_4b9f_35cbc2fdb666 -->|calls| 7052be7e_b5c9_7a95_ee8a_73a3c05abcb2 4bc7203c_0a34_d1e4_0d06_0db58ee2a28e["createEmptyVNode()"] 7052be7e_b5c9_7a95_ee8a_73a3c05abcb2 -->|calls| 4bc7203c_0a34_d1e4_0d06_0db58ee2a28e 97ceaa96_dc73_11db_99c0_3dfa1b31b53f["createComponent()"] 7052be7e_b5c9_7a95_ee8a_73a3c05abcb2 -->|calls| 97ceaa96_dc73_11db_99c0_3dfa1b31b53f 15b11929_2d26_eafe_845f_8ec8739a1d33["applyNS()"] 7052be7e_b5c9_7a95_ee8a_73a3c05abcb2 -->|calls| 15b11929_2d26_eafe_845f_8ec8739a1d33 1146917f_bf65_5455_f71b_21f7074f984b["registerDeepBindings()"] 7052be7e_b5c9_7a95_ee8a_73a3c05abcb2 -->|calls| 1146917f_bf65_5455_f71b_21f7074f984b style 7052be7e_b5c9_7a95_ee8a_73a3c05abcb2 fill:#6366f1,stroke:#818cf8,color:#fff
Relationship Graph
Source Code
src/core/vdom/create-element.ts lines 46–140
export function _createElement(
context: Component,
tag?: string | Component | Function | Object,
data?: VNodeData,
children?: any,
normalizationType?: number
): VNode | Array<VNode> {
if (isDef(data) && isDef((data as any).__ob__)) {
__DEV__ &&
warn(
`Avoid using observed data object as vnode data: ${JSON.stringify(
data
)}\n` + 'Always create fresh vnode data objects in each render!',
context
)
return createEmptyVNode()
}
// object syntax in v-bind
if (isDef(data) && isDef(data.is)) {
tag = data.is
}
if (!tag) {
// in case of component :is set to falsy value
return createEmptyVNode()
}
// warn against non-primitive key
if (__DEV__ && isDef(data) && isDef(data.key) && !isPrimitive(data.key)) {
warn(
'Avoid using non-primitive value as key, ' +
'use string/number value instead.',
context
)
}
// support single function children as default scoped slot
if (isArray(children) && isFunction(children[0])) {
data = data || {}
data.scopedSlots = { default: children[0] }
children.length = 0
}
if (normalizationType === ALWAYS_NORMALIZE) {
children = normalizeChildren(children)
} else if (normalizationType === SIMPLE_NORMALIZE) {
children = simpleNormalizeChildren(children)
}
let vnode, ns
if (typeof tag === 'string') {
let Ctor
ns = (context.$vnode && context.$vnode.ns) || config.getTagNamespace(tag)
if (config.isReservedTag(tag)) {
// platform built-in elements
if (
__DEV__ &&
isDef(data) &&
isDef(data.nativeOn) &&
data.tag !== 'component'
) {
warn(
`The .native modifier for v-on is only valid on components but it was used on <${tag}>.`,
context
)
}
vnode = new VNode(
config.parsePlatformTagName(tag),
data,
children,
undefined,
undefined,
context
)
} else if (
(!data || !data.pre) &&
isDef((Ctor = resolveAsset(context.$options, 'components', tag)))
) {
// component
vnode = createComponent(Ctor, data, context, children, tag)
} else {
// unknown or unlisted namespaced elements
// check at runtime because it may get assigned a namespace when its
// parent normalizes children
vnode = new VNode(tag, data, children, undefined, undefined, context)
}
} else {
// direct component options / constructor
vnode = createComponent(tag as any, data, context, children)
}
if (isArray(vnode)) {
return vnode
} else if (isDef(vnode)) {
if (isDef(ns)) applyNS(vnode, ns)
if (isDef(data)) registerDeepBindings(data)
return vnode
} else {
return createEmptyVNode()
}
}
Domain
Subdomains
Called By
Source
Frequently Asked Questions
What does _createElement() do?
_createElement() is a function in the vue codebase.
What does _createElement() call?
_createElement() calls 4 function(s): applyNS, createComponent, createEmptyVNode, registerDeepBindings.
What calls _createElement()?
_createElement() is called by 1 function(s): createElement.
Analyze Your Own Codebase
Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.
Try Supermodel Free