Home / File/ class.ts — vue Source File

class.ts — vue Source File

Architecture documentation for class.ts, a typescript file in the vue codebase. 3 imports, 1 dependents.

File typescript WebPlatform RuntimeModules 3 imports 1 dependents 1 functions

Entity Profile

Dependency Diagram

graph LR
  8fdc3f66_a6b3_ca41_84c0_e583884cca12["class.ts"]
  156bf2e1_8a13_f22d_5437_54f14bcef8fa["util"]
  8fdc3f66_a6b3_ca41_84c0_e583884cca12 --> 156bf2e1_8a13_f22d_5437_54f14bcef8fa
  81ed4f13_7d68_6e21_7425_cf978f68576f["vnode"]
  8fdc3f66_a6b3_ca41_84c0_e583884cca12 --> 81ed4f13_7d68_6e21_7425_cf978f68576f
  148abdbd_b24a_66f6_25f5_6786df341ad2["index"]
  8fdc3f66_a6b3_ca41_84c0_e583884cca12 --> 148abdbd_b24a_66f6_25f5_6786df341ad2
  227f73c4_4e20_2188_e5c5_a61fcdcc0b12["index.ts"]
  227f73c4_4e20_2188_e5c5_a61fcdcc0b12 --> 8fdc3f66_a6b3_ca41_84c0_e583884cca12
  style 8fdc3f66_a6b3_ca41_84c0_e583884cca12 fill:#6366f1,stroke:#818cf8,color:#fff

Relationship Graph

Source Code

import { isDef, isUndef } from 'shared/util'
import type { VNodeData } from 'types/vnode'

import { concat, stringifyClass, genClassForVnode } from 'web/util/index'

function updateClass(oldVnode: any, vnode: any) {
  const el = vnode.elm
  const data: VNodeData = vnode.data
  const oldData: VNodeData = oldVnode.data
  if (
    isUndef(data.staticClass) &&
    isUndef(data.class) &&
    (isUndef(oldData) ||
      (isUndef(oldData.staticClass) && isUndef(oldData.class)))
  ) {
    return
  }

  let cls = genClassForVnode(vnode)

  // handle transition classes
  const transitionClass = el._transitionClasses
  if (isDef(transitionClass)) {
    cls = concat(cls, stringifyClass(transitionClass))
  }

  // set the class
  if (cls !== el._prevClass) {
    el.setAttribute('class', cls)
    el._prevClass = cls
  }
}

export default {
  create: updateClass,
  update: updateClass
}

Domain

Subdomains

Functions

Dependencies

  • index
  • util
  • vnode

Frequently Asked Questions

What does class.ts do?
class.ts is a source file in the vue codebase, written in typescript. It belongs to the WebPlatform domain, RuntimeModules subdomain.
What functions are defined in class.ts?
class.ts defines 1 function(s): updateClass.
What does class.ts depend on?
class.ts imports 3 module(s): index, util, vnode.
What files import class.ts?
class.ts is imported by 1 file(s): index.ts.
Where is class.ts in the architecture?
class.ts is located at src/platforms/web/runtime/modules/class.ts (domain: WebPlatform, subdomain: RuntimeModules, directory: src/platforms/web/runtime/modules).

Analyze Your Own Codebase

Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.

Try Supermodel Free