143 lines
3.6 KiB
JavaScript
143 lines
3.6 KiB
JavaScript
|
/* eslint no-loop-func: 0, no-console: 0 */
|
|||
|
|
|||
|
export function generateData (x = 3, y = 2, z = 1, gData = []) {
|
|||
|
// x:每一级下的节点总数。y:每级节点里有y个节点、存在子节点。z:树的level层级数(0表示一级)
|
|||
|
function _loop (_level, _preKey, _tns) {
|
|||
|
const preKey = _preKey || '0'
|
|||
|
const tns = _tns || gData
|
|||
|
|
|||
|
const children = []
|
|||
|
for (let i = 0; i < x; i++) {
|
|||
|
const key = `${preKey}-${i}`
|
|||
|
tns.push({
|
|||
|
label: `${key}-label`,
|
|||
|
value: `${key}-value`,
|
|||
|
key,
|
|||
|
disabled: key === '0-0-0-1' || false,
|
|||
|
})
|
|||
|
if (i < y) {
|
|||
|
children.push(key)
|
|||
|
}
|
|||
|
}
|
|||
|
if (_level < 0) {
|
|||
|
return tns
|
|||
|
}
|
|||
|
const __level = _level - 1
|
|||
|
children.forEach((key, index) => {
|
|||
|
tns[index].children = []
|
|||
|
return _loop(__level, key, tns[index].children)
|
|||
|
})
|
|||
|
}
|
|||
|
_loop(z)
|
|||
|
return gData
|
|||
|
}
|
|||
|
export function calcTotal (x = 3, y = 2, z = 1) {
|
|||
|
/* eslint no-param-reassign:0*/
|
|||
|
const rec = (n) => n >= 0 ? x * Math.pow(y, n--) + rec(n) : 0
|
|||
|
return rec(z + 1)
|
|||
|
}
|
|||
|
console.log('总节点数(单个tree):', calcTotal())
|
|||
|
export const gData = generateData()
|
|||
|
|
|||
|
export function generateTreeNodes (treeNode) {
|
|||
|
const arr = []
|
|||
|
const key = treeNode.eventKey
|
|||
|
for (let i = 0; i < 3; i++) {
|
|||
|
arr.push({ label: `${key}-${i}-label`, value: `${key}-${i}-value`, key: `${key}-${i}` })
|
|||
|
}
|
|||
|
return arr
|
|||
|
}
|
|||
|
|
|||
|
function setLeaf (treeData, curKey, level) {
|
|||
|
const loopLeaf = (data, lev) => {
|
|||
|
const l = lev - 1
|
|||
|
data.forEach((item) => {
|
|||
|
if ((item.key.length > curKey.length) ? item.key.indexOf(curKey) !== 0
|
|||
|
: curKey.indexOf(item.key) !== 0) {
|
|||
|
return
|
|||
|
}
|
|||
|
if (item.children) {
|
|||
|
loopLeaf(item.children, l)
|
|||
|
} else if (l < 1) {
|
|||
|
item.isLeaf = true
|
|||
|
}
|
|||
|
})
|
|||
|
}
|
|||
|
loopLeaf(treeData, level + 1)
|
|||
|
}
|
|||
|
|
|||
|
export function getNewTreeData (treeData, curKey, child, level) {
|
|||
|
const loop = (data) => {
|
|||
|
if (level < 1 || curKey.length - 3 > level * 2) return
|
|||
|
data.forEach((item) => {
|
|||
|
if (curKey.indexOf(item.key) === 0) {
|
|||
|
if (item.children) {
|
|||
|
loop(item.children)
|
|||
|
} else {
|
|||
|
item.children = child
|
|||
|
}
|
|||
|
}
|
|||
|
})
|
|||
|
}
|
|||
|
loop(treeData)
|
|||
|
setLeaf(treeData, curKey, level)
|
|||
|
}
|
|||
|
|
|||
|
function loopData (data, callback) {
|
|||
|
const loop = (d, level = 0) => {
|
|||
|
d.forEach((item, index) => {
|
|||
|
const pos = `${level}-${index}`
|
|||
|
if (item.children) {
|
|||
|
loop(item.children, pos)
|
|||
|
}
|
|||
|
callback(item, index, pos)
|
|||
|
})
|
|||
|
}
|
|||
|
loop(data)
|
|||
|
}
|
|||
|
|
|||
|
function isPositionPrefix (smallPos, bigPos) {
|
|||
|
if (bigPos.length < smallPos.length) {
|
|||
|
return false
|
|||
|
}
|
|||
|
// attention: "0-0-1" "0-0-10"
|
|||
|
if ((bigPos.length > smallPos.length) && (bigPos.charAt(smallPos.length) !== '-')) {
|
|||
|
return false
|
|||
|
}
|
|||
|
return bigPos.substr(0, smallPos.length) === smallPos
|
|||
|
}
|
|||
|
// console.log(isPositionPrefix("0-1", "0-10-1"));
|
|||
|
|
|||
|
export function getFilterValue (val, sVal, delVal) {
|
|||
|
const allPos = []
|
|||
|
const delPos = []
|
|||
|
loopData(gData, (item, index, pos) => {
|
|||
|
if (sVal.indexOf(item.value) > -1) {
|
|||
|
allPos.push(pos)
|
|||
|
}
|
|||
|
if (delVal.indexOf(item.value) > -1) {
|
|||
|
delPos.push(pos)
|
|||
|
}
|
|||
|
})
|
|||
|
const newPos = []
|
|||
|
delPos.forEach((item) => {
|
|||
|
allPos.forEach((i) => {
|
|||
|
if (isPositionPrefix(item, i) || isPositionPrefix(i, item)) {
|
|||
|
// 过滤掉 父级节点 和 所有子节点。
|
|||
|
// 因为 node节点 不选时,其 父级节点 和 所有子节点 都不选。
|
|||
|
return
|
|||
|
}
|
|||
|
newPos.push(i)
|
|||
|
})
|
|||
|
})
|
|||
|
const newVal = []
|
|||
|
if (newPos.length) {
|
|||
|
loopData(gData, (item, index, pos) => {
|
|||
|
if (newPos.indexOf(pos) > -1) {
|
|||
|
newVal.push(item.value)
|
|||
|
}
|
|||
|
})
|
|||
|
}
|
|||
|
return newVal
|
|||
|
}
|