Home / Function/ _createElement() — vue Function Reference

_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

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