| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152 |
- var helperCreateTreeFunc = require('./helperCreateTreeFunc')
- var arrayEach = require('./arrayEach')
- var assign = require('./assign')
- function searchTreeItem (matchParent, parent, obj, iterate, context, path, node, parseChildren, opts) {
- var paths, nodes, rest, isMatch, hasChild
- var rests = []
- var hasOriginal = opts.original
- var sourceData = opts.data
- var mapChildren = opts.mapChildren || parseChildren
- var isEvery = opts.isEvery
- arrayEach(obj, function (item, index) {
- paths = path.concat(['' + index])
- nodes = node.concat([item])
- isMatch = (matchParent && !isEvery) || iterate.call(context, item, index, obj, paths, parent, nodes)
- hasChild = parseChildren && item[parseChildren]
- if (isMatch || hasChild) {
- if (hasOriginal) {
- rest = item
- } else {
- rest = assign({}, item)
- if (sourceData) {
- rest[sourceData] = item
- }
- }
- rest[mapChildren] = searchTreeItem(isMatch, item, item[parseChildren], iterate, context, paths, nodes, parseChildren, opts)
- if (isMatch || rest[mapChildren].length) {
- rests.push(rest)
- }
- } else if (isMatch) {
- rests.push(rest)
- }
- })
- return rests
- }
- /**
- * 从树结构中根据回调查找数据
- *
- * @param {Object} obj 对象/数组
- * @param {Function} iterate(item, index, items, path, parent, nodes) 回调
- * @param {Object} options {children: 'children'}
- * @param {Object} context 上下文
- * @return {Array}
- */
- var searchTree = helperCreateTreeFunc(function (parent, obj, iterate, context, path, nodes, parseChildren, opts) {
- return searchTreeItem(0, parent, obj, iterate, context, path, nodes, parseChildren, opts)
- })
- module.exports = searchTree
|