Blame view

juvenile-prosecution-vue/src/utils/props-util.js 2.68 KB
6c637641   wxy   no message
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
  /**
   * 该文件截取自 "ant-design-vue/es/_util/props-util.js" 文件,并对其做出特殊修改
   */
  function classNames() {
    let classes = []
  
    for (let i = 0; i < arguments.length; i++) {
      let arg = arguments[i]
      if (!arg) continue
  
      let argType = typeof arg
  
      if (argType === 'string' || argType === 'number') {
        classes.push(arg)
      } else if (Array.isArray(arg) && arg.length) {
        let inner = classNames.apply(null, arg)
        if (inner) {
          classes.push(inner)
        }
      } else if (argType === 'object') {
        for (let key in arg) {
          if (arg.hasOwnProperty(key) && arg[key]) {
            classes.push(key)
          }
        }
      }
    }
    return classes.join(' ')
  }
  
  const camelizeRE = /-(\w)/g
  
  function camelize(str) {
    return str.replace(camelizeRE, (_, c) => (c ? c.toUpperCase() : ''))
  }
  
  
  function objectCamelize(obj) {
    let res = {}
    Object.keys(obj).forEach(k => (res[camelize(k)] = obj[k]))
    return res
  }
  
  function parseStyleText(cssText = '', camel) {
    const res = {}
    const listDelimiter = /;(?![^(]*\))/g
    const propertyDelimiter = /:(.+)/
    cssText.split(listDelimiter).forEach(function (item) {
      if (item) {
        const tmp = item.split(propertyDelimiter)
        if (tmp.length > 1) {
          const k = camel ? camelize(tmp[0].trim()) : tmp[0].trim()
          res[k] = tmp[1].trim()
        }
      }
    })
    return res
  }
  
  export function getClass(ele) {
    let data = {}
    if (ele.data) {
      data = ele.data
    } else if (ele.$vnode && ele.$vnode.data) {
      data = ele.$vnode.data
    }
    const tempCls = data.class || {}
    const staticClass = data.staticClass
    let cls = {}
    staticClass &&
    staticClass.split(' ').forEach(c => {
      cls[c.trim()] = true
    })
    if (typeof tempCls === 'string') {
      tempCls.split(' ').forEach(c => {
        cls[c.trim()] = true
      })
    } else if (Array.isArray(tempCls)) {
      classNames(tempCls)
        .split(' ')
        .forEach(c => {
          cls[c.trim()] = true
        })
    } else {
      cls = { ...cls, ...tempCls }
    }
    return cls
  }
  
  export function getStyle(ele, camel) {
  
    getClass(ele)
  
    let data = {}
    if (ele.data) {
      data = ele.data
    } else if (ele.$vnode && ele.$vnode.data) {
      data = ele.$vnode.data
    }
  
    // update-begin-author:sunjianlei date:20200303 for: style 和 staticStyle 可以共存
    let style = data.style || {}
    let staticStyle = data.staticStyle
    staticStyle = staticStyle ? objectCamelize(data.staticStyle) : {}
    // update-end-author:sunjianlei date:20200303 for: style 和 staticStyle 可以共存
  
    if (typeof style === 'string') {
      style = parseStyleText(style, camel)
    } else if (camel && style) {
      // 驼峰化
      style = objectCamelize(style)
    }
    return { ...staticStyle, ...style }
  }