el-tree文字显示不全的解决办法

目录
  • 方法一: 最简单的设置横向滚动条
  • 方法二(新): 添加拖拽条改变外层容器宽度
  • 方法二(老): 添加拖拽条改变外层容器宽度
  • 方法三: 通过...表示 鼠标移上去显示全称

使用element ui的树组件el-tree时,经常出现如下问题:

el-tree渲染时因为文字内容长度不一致,导致过长的文字无法显示完全。

经尝试发现如下三种解决方法,推荐方法三。

方法一: 最简单的设置横向滚动条

效果:

在当前树节点的span标签上设置样式

overflow: auto;
// 或者
overflow-x: auto;

问题:

因为只有在最内层span层设置overflow时,能有效控制超出部分的显示,导致多个文字超长部分都有横向滚动条出现,有点丑。即便是在上一层label层添加overflow一样还是丑。所以问题等于没解决。下一个

方法二(新): 添加拖拽条改变外层容器宽度

效果:

代码:

html 注意四个部分的id绑定即可

<el-container id="dept">
    <el-aside width="220px" id="drag-dept-left">
    </el-aside>
    <div id="dragBar-dept" class="dragBar"></div>
    <el-main id="drag-dept-right" class="drag-right">
    </el-main>
</el-container>

css 仅供参考自行修改宽度控制

.dragBar {
  width: 3px;
  height: 100%;
  background: #01e4fd;
  cursor: e-resize;
}
.drag-right {
  padding-right: 0px;
  width: calc(100% - 213px);
}

js 调用

mounted () {
    // 给缩放拖动条挂载相应方法 入参(拖动条ID,左侧ID,右侧ID,外层ID)
    this.$_comFun.bindResize('dragBar-dept', 'drag-dept-left', 'drag-dept-right', 'dept')
  },

js 全局变量

export default new Vuex.Store({
    state: {
      // 拖动滚动条改变内部div宽度
      dragBar: false
    },
    mutations: {
    },
    actions: {
    },
    modules: {
    }
})

js 公共方法

import store from '../index'

// 缩放条拖动进而改变左侧div宽度方法
bindResize (barID, leftID, rightID, docID) {
    // 设置是否移动标识
    let removeFlag = false
    // 获取左边缩放的div对象
    let bar = document.getElementById(barID)
    let dragLeft = document.getElementById(leftID).style
    let dragRight = document.getElementById(rightID).style
    let doc = document.getElementById(docID)
    let x = 0 // 鼠标的 X 和 Y 轴坐标
    // 挂载鼠标事件
    bar.addEventListener('mousedown', moveDownMouse, false)
    // 注意移动和鼠标失焦事件需要绑定在dom上,若只是绑定在bar上只能在bar上移动\失焦才有效
    doc.addEventListener('mousemove', mouseMove, false)
    doc.addEventListener('mouseup', mouseUp, false)

    function moveDownMouse (e) {
      removeFlag = true
      // 按下元素后 计算当前鼠标与对象计算后的坐标
      x = e.clientX - bar.offsetWidth - dragLeft.width.replace('px', '')
      // 支持 setCapture时 捕捉焦点 // 设置事件 // 绑定事件
      if (bar.setCapture) {
        bar.setCapture()
        bar.onmousemove = function (ev) {
          mouseMove(ev || event)
        }
        bar.onmouseup = mouseUp
      } else {
        // bar.addEventListener('mousemove', mouseMove, false)
        // bar.addEventListener('mouseup', mouseUp, false)
      }
      // 防止默认事件发生
      e.preventDefault()
      store.state.dragBar = false
    }
    // 移动事件
    function mouseMove (e) {
      if (removeFlag) {
        // 宇宙超级无敌运算中
        let width = e.clientX - x
        if (width < 200) {
          dragLeft.width = '200px'
        } else if (width > 400) {
          dragLeft.width = '400px'
        } else {
          dragLeft.width = width + 'px'
        }
        // 若不计算右边宽度,拖动条会被挤压
        dragRight.width = 'calc(100% - ' + dragLeft.width + ')'
      }
    }
    // 停止事件
    function mouseUp () {
      removeFlag = false
      // 支持 releaseCapture时 // 释放焦点 // 移除事件 // 卸载事件
      if (bar.releaseCapture) {
        bar.releaseCapture()
        bar.onmousemove = bar.onmouseup = null
      } else {
        // bar.removeEventListener('mousemove', mouseMove, false)
        // bar.removeEventListener('mouseup', mouseUp, false)
      }
      store.state.dragBar = true
    }
}

方法二(老): 添加拖拽条改变外层容器宽度

效果:

添加拖拽条

<div id="dragBar"></div>

在当前组件加载完后,给拖拽条绑定事件

  mounted () {
    // 给缩放拖动条挂载相应方法 入参(拖动条对象, 左侧div的ID)
    this.bindResize(document.getElementById('dragBar'), 'menu')
  },
  methods: {
   // 缩放条拖动进而改变左侧div宽度方法
   bindResize (bar, menu) {
     /* eslint-disable */
     // 获取左边缩放的div对象
     let els = document.getElementById(menu).style
     let x = 0 // 鼠标的 X 和 Y 轴坐标
     jQuery(bar).mousedown(function (e) {
       // 按下元素后 计算当前鼠标与对象计算后的坐标
       x = e.clientX - bar.offsetWidth - jQuery('#' + menu).width()
       // 支持 setCapture时 捕捉焦点 // 设置事件 // 绑定事件
       if (bar.setCapture) {
         bar.setCapture()
         bar.onmousemove = function (ev) {
           mouseMove(ev || event)
         }
         bar.onmouseup = mouseUp
       } else {
         jQuery(document).bind('mousemove', mouseMove).bind('mouseup', mouseUp)
       }
       // 防止默认事件发生
       e.preventDefault()
     })
     // 移动事件
     function mouseMove (e) {
       // 宇宙超级无敌运算中
       els.width = e.clientX - x + 'px'
     }
     // 停止事件
     function mouseUp () {
       // 支持 releaseCapture时 // 释放焦点 // 移除事件 // 卸载事件
       if (bar.releaseCapture) {
         bar.releaseCapture()
         bar.onmousemove = bar.onmouseup = null
       } else {
         jQuery(document).unbind('mousemove', mouseMove).unbind('mouseup', mouseUp)
       }
     }
     /* eslint-enable */
   }
  }

问题:

办法是好办法,就是有点麻烦,我只是想要简单的显示完全不想拖来拖去怎么办?下一个

方法三: 通过...表示 鼠标移上去显示全称

效果:

过程:

遇到问题首先想到的就是这个解决办法,无奈绕了很多弯路才走上正道。

因为element ui官方el-tree文档里没有给节点插入title标签的说明,于是我打开源码在其对应节点的span标签强制写上title="node.name"之类的并没有任何用处。

直到看到自定义节点内容,虽然官方举例用来插入和删除节点,但是我可以把点击事件变成悬浮事件显示节点文本全内容啊。

然后选用scoped slot插入的时候发现:

最后终于结束了这个问题。

代码:

使用el-tree组件如下:

<el-tree ref="tree" :data="treeMenus" :props="multiProps" :show-checkbox="true" :node-key="nodeId">
 <span class="span-ellipsis" slot-scope="{ node, data }">
  <span :title="node.label">{{ node.label }}</span>
 </span>
</el-tree>

给span标签添加样式,通过...表示文本未完全显示:

.span-ellipsis {
  width: 100%;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}

补充说明:

如果.span-ellipsis样式设置无效,可能需要加上display: block;即为:

.span-ellipsis {
  width: 100%;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
  display: block;
}

因为我用element ui的el-tree组件,span的外层样式默认为display: flex; 则无需设置span的display属性即可。

到此这篇关于el-tree文字显示不全的解决办法的文章就介绍到这了,更多相关el-tree文字显示不全内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • ElementUI Tree 树形控件的使用并给节点添加图标

    前言: 因为项目需要用Vue做一个管理系统,其中有一个公司部门的管理页面有用到ElementUI 的树形控件,但是结构中没有使用chexkBox选项框,针对这个功能碰到的一些问题做一下总结 一,数据渲染 1)在<el-tree>标签中绑定data属性 2)在vue实例的data中声明list变量 3)从后台获取到的数据是以数组里面嵌套多个对象的结构并赋值给list, 当前的数据是OrgName为当前结构名称, Children作为子分支数组, 子分支中的结构与当前结构一致 4)在页面中展示结构

  • Element-ui tree组件自定义节点使用方法代码详解

    工作上使用到element-ui tree 组件,主要功能是要实现节点拖拽和置顶,通过自定义内容方法(render-content)渲染树代码如下~ <template> <div class="sortDiv"> <el-tree :data="sortData" draggable node-key="id" ref="sortTree" default-expand-all :expand-

  • Python中使用ElementTree解析XML示例

    [XML基本概念介绍] XML 指可扩展标记语言(eXtensible Markup Language). XML 被设计用来传输和存储数据. 概念一: 复制代码 代码如下: <foo>      # foo元素的起始标签  </foo>     # foo元素的结束标签             # note: 每一个起始标签必须有对应的结束标签来闭合, 也可以写成<foo/> 概念二: 复制代码 代码如下: <foo>           # 元素可以嵌套

  • ElementUI中el-tree节点的操作的实现

    其实tree的有些方法用起来是很方便的, this.$refs.tree.getCheckedKeys():这个原生态的方法.官方文档上说的是,返回一个数组.有了这个方法,我们就可以得到选中的每个节点的id,拿到了id,那所有的问题就迎刃而解了. 废话不多说,直接上代码 html <div id="app"> <el-row> <el-button @click="checkedKeys">得到节点id</el-button

  • 详解vue-element Tree树形控件填坑路

    通过tree树形控件的default-checked-keys属性来设置默认选中的节点 html.vue <el-form-item label="角色权限:"> <el-tree :data="data2" show-checkbox node-key="id" @check="handleNodeClick" :default-expanded-keys="[]" ref="

  • python xml.etree.ElementTree遍历xml所有节点实例详解

    python xml.etree.ElementTree遍历xml所有节点 XML文件内容: <students> <student name='刘备' sex='男' age='35'/> <student name='吕布' sex='男' age='38'/> <student name='貂蝉' sex='女' age='22'/> </students> 代码: #-*- coding: UTF-8 -*- # 从文件中读取数据 imp

  • vue elementUI tree树形控件获取父节点ID的实例

    首先找到element-ui.common.js文件 如下 具体看你工程下的node_modules D:\workSpace\vue_manage\node_modules\element-ui\lib\element-ui.common.js 找到getCheckedNodes该方法 细节如下我的该方法在21618行 TreeStore.prototype.getCheckedNodes = function getCheckedNodes() { var leafOnly = argume

  • elementUI Tree 树形控件的官方使用文档

    Tree 树形控件---官方文档地址 用清晰的层级结构展示信息,可展开或折叠. 基础用法 基础的树形结构展示. <el-tree :data="data" :props="defaultProps" @node-click="handleNodeClick"></el-tree> <script> export default { data() { return { data: [{ label: '一级 1'

  • el-tree文字显示不全的解决办法

    目录 方法一: 最简单的设置横向滚动条 方法二(新): 添加拖拽条改变外层容器宽度 方法二(老): 添加拖拽条改变外层容器宽度 方法三: 通过...表示 鼠标移上去显示全称 使用element ui的树组件el-tree时,经常出现如下问题: el-tree渲染时因为文字内容长度不一致,导致过长的文字无法显示完全. 经尝试发现如下三种解决方法,推荐方法三. 方法一: 最简单的设置横向滚动条 效果: 在当前树节点的span标签上设置样式 overflow: auto; // 或者 overflow

  • 关于python pycharm中输出的内容不全的解决办法

    很多时候我们会发现有的时候输出的结果特别多的时候,会在最后输出时用...代替,最后输出一个总长度,那要咋么弄咧? import pandas as pd # 设置显示的最大列.宽等参数,消掉打印不完全中间的省略号 # pd.set_option('display.max_columns', 1000) pd.set_option('display.width', 1000)#加了这一行那表格的一行就不会分段出现了 # pd.set_option('display.max_colwidth', 1

  • jQuery fancybox在ie浏览器下无法显示关闭按钮的解决办法

    如果版本是: 1.3.1 IE无法显示关闭按钮 如果版本是: 1.3.4 IE6无法显示关闭按钮 解决办法: Version: 1.3.1 打开fancybox.css 注释掉此行: .fancybox-ie #fancybox-close { background: transparent; filter: progid : DXImageTransform.Microsoft.AlphaImageLoader ( src = 'images/fancy_close.png', sizingM

  • 有关easyui-layout中的收缩层无法显示标题的解决办法

    easyui-layout中的收缩层无法显示标题的问题原因分析: 在easyui-layout中设置面板初始化为可以折叠,然后就发现标题还有图标都木有了 嗯,就是结果列表上面.一片空白,出现了问题就要去解决它,在网上查了资料之后呢,决定修改jquery.easyui.min.js 版本为:jQuery EasyUI 1.4.1 在5105行有_39d方法,在其中设置两个变量_Cstitle,_CsIcon添加代码如下: var _Cstitle; var _closedTitle = p.pan

  • BootStrap 图标icon符号图标glyphicons不正常显示的快速解决办法

    bootstrap 图标icon符号图标glyphicons不正常显示解决办法如下所示: 分享供各位参考: 1.在ff/http:的地址栏中输入"about:config",即进入配置界面. 2.进入后,搜索"security.fileuri.strict_origin_policy",这是该值应该是true. 3.双击该项,其值自动变为false,即可. 4.修改后,再刷新遇到问题的页面,即可看到正常显示的图标了. 探究问题原因: 1.由于ff/http:一个安全

  • jquery fancybox ie6不显示关闭按钮的解决办法

    解决办法: 打开jquery.fancybox-1.3.4.css 注释掉这行就行了: 复制代码 代码如下: .fancybox-ie6 #fancybox-close   {      background: transparent;      filter: progid:DXImageTransform.Microsoft.AlphaImageLoader(src='fancybox/fancy_close.png', sizingMethod='scale');   }

  • 大数量查询分页显示 微软的解决办法

    微软的解决办法 using System; using System.Data; using System.Data.SqlClient; using System.Drawing; using System.Windows.Forms; public class PagingSample: Form { // Form controls. Button prevBtn = new Button(); Button nextBtn = new Button(); static DataGrid 

  • PDF里的文字显示模糊的解决方法

    如何使PDF的文字显示更清晰 打开一个PDF文件-->编辑-->显示(有的版本是页面显示)-->去掉"平滑文本"前面的勾看看-->OK清晰了,只是看起来都是锯齿

  • js下在password表单内显示提示信息的解决办法

    经典有人要这个代码,考虑到password中输入的内容会显示为*号,所以要想办法解决*的问题.当初想用setAttribute动态修改type属性达到效果,再ff下测试成功,但没想到setAttribute对type属性的修改在ie中无效.最终采用背景图片的方式解决了这个.即为password设定一个背景图片,图片文字为提示信息 如:<img src="http://files.jb51.net/upload/20070819124037566.gif" />, 当鼠标放上

  • Bootstrap 3.x打印预览背景色与文字显示异常的解决

    我首先测试了一段如下的代码,发现打印预览时的确无法显示背景色. <!DOCTYPE html> <html lang="en"> <head> <meta charset="utf-8"> <title>Regonline</title> <link href="css/bootstrap.css" rel="stylesheet" /> &l

随机推荐