<!DOCTYPE html>
<html lang="zh">
<head>
<meta charset="UTF-8">
<title>Title</title>
<!-- import CSS -->
<link rel="stylesheet" href="https://unpkg.com/element-ui/lib/theme-chalk/index.css">
<style>
.el-tree{
position:absolute;
cursor:default;
background:#fff;
color:#606266;
z-index:100;
border:1px solid #dcdfe6;
border-radius:5px;
width:100%;
}
    /*elementUI vue tree 显示设置高度与滚动条*/
    .ORGTree{
      height:300px;
      overflow:auto;
    }
</style>
</head>
<body> <div id="app">
<el-form ref="projectOrg" v-model="projectOrg" label-width="140px" size="mini">
<el-form-item ref="treeParent" label="维护机构" prop="projectOrg">
<el-input @click.native="projectOrgFun($event)" v-model="searchOrgId" placeholder="请输入维护机构" readonly></el-input>
<el-tree class="ORGTree"
v-show="ishowTree"
show-checkbox
lazy
ref="tree"
highlight-current
@check-change="currentchange"
:load="getOrgList"
@node-click="handleNodeClick"
:props="defaultProps">
</el-tree>
</el-form-item>
</el-form>
</div>
<!-- import Vue before Element -->
<script src="https://unpkg.com/vue/dist/vue.js"></script>
<!-- import JavaScript -->
<script src="https://unpkg.com/element-ui/lib/index.js"></script> <script>
new Vue({
el: '#app',
data: function () {
return {
input: [],
searchOrgId: '',           //保存被选中的ID, 提交的时候按字符串提交:
// var organCodesList=this.organCodes.join(","),
// 后台解析的时候使用:
//String[] organCodes=organCodesList.split(",");
organCodes: [],
ishowTree: false,
defaultProps: {
children: 'children',
label: 'label',
},
projectOrg: '', }
}, //加载完成时调用
created: function () { },
//方法
methods: { //树型点击
currentchange(data, ischeck) {
console.log(data);
if (!ischeck) {
var index = this.input.findIndex(d => d === data.label);
this.input.splice(index, 1);
this.organCodes.splice(index, 1);
} else {
this.input.push(data.label);
this.organCodes.push(data.id);
}
console.log(this.organCodes);
var that = this;
that.$refs.tree.$el.onmouseleave = function () {
that.ishowTree = false;
}
that.searchOrgId = this.input.toString();
},
projectOrgFun(e) {
if(this.ishowTree){
this.ishowTree = false;
}else{
this.ishowTree = true;
}           //第一种方式:点击其他区域, 消失树
          document.onclick=function(){
            that.ishowTree=false;
          }
          e.stopPropagation();//阻止冒泡           //离开区域的时候树消失
var that = this;
that.$refs.tree.$el.onmouseleave = function () {
that.ishowTree = false;
} that.$refs.treeParent.$el.onmouseleave = function () {
that.ishowTree = false;
}
},
projectOrgFalse(){
this.ishowTree = false;
},
handleNodeClick(data) {
console.log(data);
}, getOrgList(node, resolve) {
let that = this;
console.log(node); //等于0表示根节点
if (node.level == 0) {
//请求数据
// that.getFirstRootNodeData(resolve); //模拟数据
var FirstRootNodeData = [{
id: '1',
label: "初始根节点01"
}, {
id: '2',
label: "初始根节点02"
}];
resolve(FirstRootNodeData);
//直接返回
return;
} else {
//请求数据(传送要请求的根节点的id)
console.log(node.data.id);
// that.getLeafNodeData(node.data.id,resolve); //模拟数据
var LeafNodeData = [{
id: '1',
label: "叶子节点01"
}, {
id: '2',
label: "叶子节点02"
}, {
id: '2',
label: "叶子节点02"
}];
resolve(LeafNodeData);
return;
}
}
},
})
</script>
</body>
</html>

显示效果:

elementUI vue tree input 懒加载 输入下拉树型示例 点击其他区域关闭自定义div的更多相关文章

  1. 代码: 两列图片瀑布流(一次后台取数据,图片懒加载。下拉后分批显示图片。图片高度未知,当图片onload后才显示容器)

    代码: 两列图片瀑布流(一次后台取数据,无ajax,图片懒加载.下拉后分批显示图片.图片高度未知,当图片onload后才显示容器) [思路]: 图片瀑布流,网上代码有多种实现方式,也有各类插件.没找到 ...

  2. ElementUI Tree控件在懒加载模式下的重新加载和模糊查询

    之所以使用懒加载是为了提高性能,而且只有在懒加载模式下默认会给所有显示节点设置展开按钮.leaf也可以做到,但是要操作数据比较麻烦. 要实现懒加载模式下的模糊查询以及重新加载必须要使用data与laz ...

  3. Vue代码分割懒加载的实现方法

    什么是懒加载 懒加载也叫延迟加载,即在需要的时候进行加载,随用随载. 为什么需要懒加载 在单页应用中,如果没有应用懒加载,运用webpack打包后的文件将会异常的大,造成进入首页时,需要加载的内容过多 ...

  4. vue.js移动端app实战4:上拉加载以及下拉刷新

    上拉加载以及下拉刷新都是移动端很常见的功能,在搜索或者一些分类列表页面常常会用到. 跟横向滚动一样,我们还是采用better-scroll这个库来实现.由于better已经更新了新的版本,之前是0.几 ...

  5. vue-scroller实现vue单页面的上拉加载和下拉刷新问题

    在vue中如何简单的实现页面的上拉加载和下拉刷新,在这里我推荐使用vue-scrolle插件. vue-scrolle的基本使用方法: 1.下载 npm i vue-scroller -D 2.导包 ...

  6. vue使用vant-ui实现上拉加载、下拉刷新和返回顶部

    vue使用vant-ui实现上拉加载.下拉刷新和返回顶部 vue现在在移动端常用的ui库有vant-ui和mint-ui,上拉加载.下拉刷新和返回顶部也是移动端最基础最常见的功能.下面就用vant-u ...

  7. vue项目中上拉加载和下拉刷新页面的实现

    功能:上拉加载,下拉刷新 使用方法: 自己创建一个.vue的文件(我自己是创建了一个PullToRefresh.vue的文件),将代码粘贴进去,具体的样式问题自己在该文件中调整. <templa ...

  8. Vue-上拉加载与下拉刷新(mint-ui:loadmore)一个页面使用多个上拉加载后冲突问题

    所遇问题: 该页面为双选项卡联动,四个部分都需要上拉加载和下拉刷新功能,使用的mint-ui的loadmore插件,分别加上上拉加载后,只有最后一个的this.$refs.loadmore.onTop ...

  9. UITableView与UISearchController搜索及上拉加载,下拉刷新

    #import "ViewController.h" #import "TuanGouModel.h" #import "TuanGouTableVi ...

随机推荐

  1. Java 线程池的原理及实现

    1.线程池简介: 多线程技术主要解决处理器单元内多个线程执行的问题,它可以显著减少处理器单元的闲置时间,增加处理器单元的吞吐能力. 假设一个服务器完成一项任务所需时间为:T1 创建线程时间,T2 在线 ...

  2. Oracle实战笔记(第一天)

    导读 笔记内容来自韩顺平老师的视频<玩转Oracle实战教程>,可以结合笔记进行观看.第一天视频中还有Oracle的介绍和安装等内容,很容易搜索到,这里就不再进行总结. 目录 1.命令行工 ...

  3. LabVIEW(五):DAQ同步

    1.在许多的测试测量应用当中,我们会需要在通过一个时间段内进行同步测量. 同步采集通常分为两类: (1).同时测量:即不同的任务在同一时刻开始.举例来说,我们会在一个模拟输入通道上采集数据,同时在一个 ...

  4. 几个java小例子

    比较两个字符串的值: /*------------------------比较两个字符串的值----------------------*/ String st1="hello"; ...

  5. vue脚手架中使用axios

    虽然之前用过n次,但大多都是直接在页面中引入axios.js的.今天想换种方式使用,一时间竟不知道怎么配置了.特此记录下. 1.npm 安装axios,文件根目录下安装,指令如下:  npm inst ...

  6. swiper在vue项目中的循环轮播bug以及点击事件

    一般的,如果是静态数据(本地数据),可以直接在mounted生命周期中初始化,循环轮播.自动播放都比较正常. 但是,如果是动态从后台获取数据的话,采用上述方法会发现,轮播图无法自动播放,也无法拖拽. ...

  7. ASP.NET Core 2.1 使用Docker运行

    重要提示,本文为 ASP.NET Core 2.1 如果你是 2.2 那么请将文中的镜像换为 microsoft/dotnet:2.2.0-aspnetcore-runtime 即可,其他操作一样 1 ...

  8. 微软Cloud+AI本地化社区贡献指南

    本文主要介绍微软Cloud+AI本地化社区,以及通过多种途径贡献本地化的操作指南. 什么是本地化社区 Cloud+AI本地化社区是微软技术社区的组成部分之一,负责对微软官方技术文档本地化的支持工作.微 ...

  9. mysql 开发基础系列21 事务控制和锁定语句(下)

    1.  隐含的执行unlock tables 如果在锁表期间,用start transaction命令来开始一个新事务,会造成一个隐含的unlock tables 被执行,如下所示: 会话1 会话2 ...

  10. Tomcat(一):背景知识和安装tomcat

    Tomcat系列文章:http://www.cnblogs.com/f-ck-need-u/p/7576137.html 1. 基础背景知识 1.1 java和jdk概念 无论是何种程序,要能在计算机 ...