viewui tree 自定义化(源码copy出来改动)#添加 获取selected 解决方案
需求:
对树有title的点击效果,右侧有说明文字 和 按钮能点击,不能右键,系统用的壳已经有右键了。
出现的问题:
viewui的tree有两年没更新了,对ui这块,是采取的render自定义,但是它外层包裹了title,包括事件等等。导致右侧再加按钮就会在title里面。
问题2: 单行背景通下来
这个是由于用的折叠面板 ul li 从这个层级,就得修改css

临时效果

代码部分 node.vue

viewui源码 都copy过来

SubModeTree.vue
<template>
<div>
<div style="height: 34px; border-bottom: 1px solid #e5e5e5;">
<div style="float: left; font-size: 16px; font-weight: bold; padding: 4px 0 0 10px;">XXXXXX树</div>
<div style="float: right;padding-top: 5px;">
<Checkbox v-model="subFlag">包含下级数据</Checkbox>
</div>
</div>
<div style="height: 10px;"></div>
<div style="padding: 0 10px 10px 10px; height: calc(100vh - 221px); overflow: auto;">
<TreeZen :data="treeData"
:render="renderContent"
class="tree-render-sub-mode"></TreeZen>
</div>
</div>
</template>
<script>
import SubModeTreeItem from './SubModeTreeItem'
import TreeZen from '@/components/ViewuiZen/components/tree'
export default {
name: 'SubModeTree',
components: {
TreeZen
},
data () {
return {
subFlag: true,
treeData: [],
treeDataRaw: [{ title: '全国', expand: true }]
}
},
methods: {
append (data, children) {
this.$set(data, 'children', children)
},
bindRender (arr) {
return arr.map(item => {
// item.render = this.renderItem
// item.children = []
return item
})
},
renderContent (h, { root, node, data }) {
return h(SubModeTreeItem, {
props: {
item: data
}
})
}
},
created () {
let t = [...this.treeDataRaw]
// t[0].children = this.bindRender(this.treeDataRaw)
this.append(t[0], [{ title: '北京市' }, { title: '天津市' }, { title: '广东省' }, { title: '河北省' }])
this.append(t[0].children[1], [{ title: '和平区' }, { title: '南开区' }])
this.treeData = [...t]
console.info('treeData', this.treeData)
},
mounted () {
}
}
</script>
<style>
.tree-render-sub-mode .ivu-tree-title {
/*width: 95%;*/
}
</style>
SubModeTreeItem.vue
<template>
<span class="subModeTreeBg" style="height: 30px; line-height: 30px; font-size: 14px;">
<span v-if="item.isTitle" @click="titleClickHandleByTreeBySubMode">
<Icon type="ios-folder-open" size="21" color="#f2994a" style="margin-right:8px;"/>
<span>{{ item.title }}</span>
</span>
<span v-if="!item.isTitle">
<Icon type="ios-checkmark-circle" size="21" color="#27ae60"/>
同步成功
</span>
<!--<Button @click="btnClickHandleByTreeBySubMode"-->
<!--type="text" size="small" style="margin-left: 5px; color:#27ae60; position: absolute; right: 0;">-->
<!--</Button>-->
</span>
</template>
<script>
export default {
name: 'SubModeTreeItem',
props: {
item: {
type: Object,
default () {
return {}
}
}
},
data () {
return {}
},
methods: {
titleClickHandleByTreeBySubMode () {
console.info('titleClickHandleByTreeBysubMode item', this.item)
},
btnClickHandleByTreeBySubMode () {
console.info('btnClickHandleByTreeBySubMode item', this.item)
}
}
}
</script>
<style>
.ivu-tree-title-selected {
}
.ivu-tree-title-selected .subModeTreeBg {
/*background-color: #2db7f5;*/
}
.ivu-tree-arrow {
margin-top: 5px;
}
</style>
来源 版本号 4.6.1
viewui 的版本号,用的这版copy的,以后要是再有组件,就不用把环境再copy一遍了,就光把相关的组件copy上就ok了。
20210720 日志更新
获取selected 解决方案
点击事件获取 selected 数据不准,经查看,是因为点击事件的时候,数据还没有进行改变。点击事件后,数据进行的改变。
解决方案: 延时获取数据
titleClickHandle (item, root) {
// 点击事件后,数据selected状态进行更改,但是点击的时候,数据还没有更改,所以延时获取selected
setTimeout(() => {
const selected = root.filter(d => d.nodeKey === item.nodeKey)[0].node.selected
console.info('selected', selected)
}, 20)
},
click 点击范围问题
问题:因为tree的点击事件有两套 一套在外层 node.vue 里面

里面的click

解决方案:外层的padding设置为0
padding换到里面
这个的难点在于发现此bug,我也是无意间点到的。
viewui tree 自定义化(源码copy出来改动)#添加 获取selected 解决方案的更多相关文章
- Android必学-异步加载+Android自定义View源码【申明:来源于网络】
Android必学-异步加载+Android自定义View源码[申明:来源于网络] 异步加载地址:http://download.csdn.net/detail/u013792369/8867609 ...
- Java自定义注解源码+原理解释(使用Java自定义注解校验bean传入参数合法性)
Java自定义注解源码+原理解释(使用Java自定义注解校验bean传入参数合法性) 前言:由于前段时间忙于写接口,在接口中需要做很多的参数校验,本着简洁.高效的原则,便写了这个小工具供自己使用(内容 ...
- spring security 授权方式(自定义)及源码跟踪
spring security 授权方式(自定义)及源码跟踪 这节我们来看看spring security的几种授权方式,及简要的源码跟踪.在初步接触spring security时,为了实现它的 ...
- Spring事务源码解析(二)获取增强
在上一篇文章@EnableTransactionManagement注解解析中,我们搭建了源码阅读的环境,以及解析了开启Spring事务功能的注解@EnableTransactionManagemen ...
- jquery-ui-datepicker定制化,汉化,因手机布局美观化源码修改
感谢浏览,欢迎交流=.= 公司微信网页需要使用日历控件,想到jquery-mobile,但是css影响页面布局,放弃后使用jquery-ui-datepicker. 话不多说,进入正题: 1.jque ...
- select2插件改造之设置自定义选项 源码
改造特性: 适应业务需要,选项里面包含“其他”其它”,可以点击填写并设置自定义选项 效果图: 具体代码不做阐述,如有类似需求,请私信.主要源码: /* Copyright 2012 Igor Vayn ...
- recovery编译汉化源码开源地址
本Recovery基于xiaolu开源的不完全汉化版源码,进行完全汉化,并合并Philz的最新源码. 汉化耗费我将近一整天的精力,纯手打,可能有遗漏或翻译不准的地方,请到微博反馈 本Rec完全开源,便 ...
- 基于zuul实现自定义路由源码分析
ZuulFilter定义 通过继承ZuulFilter我们可以定义一个新的过滤器,如下 public class IpAddressFilter extends ZuulFilter { @Autow ...
- adaptiveThreshold自适应二值化源码分析
自适应二值化介绍: 二值化算法是用输入像素的值I与一个值C来比较,根据比较结果确定输出值. 自适应二值化的每一个像素的比较值C都不同,比较值C由这个像素为中心的一个块范围计算在减去差值delta得到. ...
- Universal-Image-Loader源码解解析---display过程 + 获取bitmap过程
Universal-Image-Loader在github上的地址:https://github.com/nostra13/Android-Universal-Image-Loader 它的基本使用请 ...
随机推荐
- 【三】gym简单画图、快来上手入门吧,超级简单!
相关文章: [一]gym环境安装以及安装遇到的错误解决 [二]gym初次入门一学就会-简明教程 [三]gym简单画图 [四]gym搭建自己的环境,全网最详细版本,3分钟你就学会了! [五]gym搭建自 ...
- 14.4 Socket 双向数据通信
所谓双向数据传输指的是客户端与服务端之间可以无差异的实现数据交互,此类功能实现的核心原理是通过创建CreateThread()函数多线程分别接收和发送数据包,这样一旦套接字被建立则两者都可以异步发送消 ...
- CE修改器入门:查找多级指针
本关是第6关的加强版,CE 6.X 教程中的4级指针比5.X的要简单些.多级指针就像玩解谜游戏一样,谜团不只一个,盒子中还有盒子.这里面是4级指针,游戏中也有比如8级指针,12级指针等等,思路都是一样 ...
- 树莓派4B改造成云桌面客户端,连接DoraCloud免费版
Raspberry Pi(树莓派) 是为学习计算机编程教育而设计的只有信用卡大小的微型电脑,自问世以来受众多计算机发烧友和创客的追捧,曾经一"派"难求. DoraCloud是一款多 ...
- ADG备库中某个PDB缺失temp文件
之前认为缺失的temp文件在开库时会自动创建,但其实也有不能自动创建的场景,alert会有类似如下提示: 2023-05-11T20:35:35.974983+08:00 AWR(6):******* ...
- 好书推荐之《JAVA编程思想》
名人推荐 真是一本透着编程思想的书. 上面的书让你从微观角度了解 Java,而这本书则可以让你从一个宏观角度了解 Java. 这本书和 Java 核心技术的厚度差不多,但这本书的信息密度比较大. 所以 ...
- 【React】排查两小时,修改一个词,记一个因代码书写不规范导致的生命周期BUG
壹 ❀ 引 因为现在工作主要以修bug为主,日常工作中总是会接触到千奇百怪的前端问题,它可能是代码缺陷导致的程序错误,也可能是方案不合理造成的性能问题,老实说修bug是一件很枯燥的事情,你需要阅读大量 ...
- JS 判断对象属性是否存在,判断是否包含某个属性,是否为自身属性
壹 ❀ 引 看过博主JS 疫情宅在家,学习不能停,七千字长文助你彻底弄懂原型与原型链这篇文章的同学应该知道,文中有专门介绍这个问题.那么为什么我要另起一篇再说一次呢?原因有两个,一是介绍原型与原型链的 ...
- NC16591 [NOIP2010]关押罪犯
题目链接 题目 题目描述 S 城现有两座监狱,一共关押着N 名罪犯,编号分别为1~N.他们之间的关系自然也极不和谐.很多罪犯之间甚至积怨已久,如果客观条件具备则随时可能爆发冲突.我们用"怨气 ...
- Ehcache 3.x 笔记
现在Ehcache版本已经到3.10了, 网上查到的大部分还是2.x版本的使用说明, 把基础用法记了一下, 以后有时间再翻译. 基础使用, 创建 CacheManager CacheManager c ...