由于功能性需求:需要展示一个树状结构的导航界面

1.进行资源引用

<!-- Required Stylesheets -->
<link href="bootstrap.css" rel="stylesheet">
<!-- Required Javascript -->
<script src="jquery.js"></script>
<script src="bootstrap-treeview.js"></script>

2.需要一个DOM元素绑定该组件:

<div id="tree"></div>
基本用法是这样:

$('#tree').treeview({
data: getTree(), // 获取数据节点
levels: 5,//节点层级数
color: "#000",//每一级通用的 节点字体颜色
backColor: "#fff",//每一级通用的 节点字背景色
onhoverColor: "orange",//选中浮动颜色
borderColor: "red",//设置组件的边框颜色; 设置showBorder为false,如果你不想要一个可见的边框
showBorder: false,
showTags: true,//是否在每个节点的右侧显示标签。 其值必须在每个节点的数据结构中提供

highlightSelected: true,//是否突出显示选定的节点
selectedColor: "#fff",//设置选定节点的前景色
selectedBackColor: "darkorange",//设置选定节点的背景色

});

以这种方式进行数据绑定以及初始界面色彩效果的设置,默认点击效果第一次选中,第二次点击会选中效果会消失。通过设置onhoverColor属性,可以将节点一直处于选中效果。

------------------------树状数据结构------------------------------------

function getTree() {

var tree = [
{
text: "Parent 1",
nodes: [
{
text: "Child 1",
nodes: [
{
text: "Grandchild 1"
},
{
text: "Grandchild 2"
}
]
},
{
text: "Child 2"
}
]
},
{
text: "Parent 2"
},
{
text: "Parent 3"
},
{
text: "Parent 4"
},
{
text: "Parent 5"
}
];

return tree;
}

3.通过学习查找资料,可以给每个节点添加li点击事件,实现每个节点的点击操作
<li class="list-group-item" onclick="itemOnclick(this)"></li>

function itemOnclick(target) {

if (target.childNodes.length > 3) {
var val = target.childNodes[3].data;
$("#UserId").find("option[value='" + val + "']").attr("selected", "selected");
$("#UserId_flexselect")["0"].value = val;
}
//找到当前节点id
var nodeid = $(target).attr('data-nodeid');
var tree = $('#tree');
//获取当前节点对象
var node = tree.treeview('getNode', nodeid);
if (lastnode != null && target.children.length <= 2 ) {
var nodeidlast = $(lastnode).attr('data-nodeid');
var tree = $('#tree');
//获取当前节点对象
var nodelast = tree.treeview('getNode', nodeidlast);
tree.treeview('collapseNode', nodelast.nodeId);
}


 

最终结果:花了不少时间迷糊:

最后效果:

扩展:还剩下好多属性,没有时间研究:后续再慢慢看吧

$('#tree').treeview({
data: getTree(), // 获取数据节点
levels: 5,//节点层级数
color: "#000",//每一级通用的 节点字体颜色
backColor: "#fff",//每一级通用的 节点字背景色
onhoverColor: "orange",//选中浮动颜色
borderColor: "red",//设置组件的边框颜色; 设置showBorder为false,如果你不想要一个可见的边框
showBorder: false,
showTags: true,//是否在每个节点的右侧显示标签。 其值必须在每个节点的数据结构中提供

highlightSelected: true,//是否突出显示选定的节点
selectedColor: "#fff",//设置选定节点的前景色
selectedBackColor: "darkorange",//设置选定节点的背景色

});

节点属性

定义以下属性以允许节点级别覆盖,如节点特定的图标,颜色和标记

text

String Mandatory  字符串 必需

显示给定树节点的文本值,通常位于节点图标的右侧

icon

String Optional 字符串 可选

显示在给定节点上的图标,通常位于文本的左侧。

为简单起见,我们直接利用Bootstraps Glyphicons支持,因此您应该提供由空格分隔的基类和个别图标类。

通过提供基类,您可以完全控制所使用的图标。 如果你想使用自己的,那么只需将您的类添加到此图标字段

selectedIcon

String Optional 字符串 可选

选定时显示在给定节点上的图标,通常位于文本的左侧

color

String Optional 字符串 可选

在给定节点上使用的前景颜色将覆盖全局颜色选项

backColor

String Optional 字符串 可选

给定节点上使用的背景颜色将覆盖全局颜色选项

href

String Optional 字符串 可选

与全局enableLinks选项一起使用,以指定给定节点上的锚点标记URL

selectable

布尔值 默认值:true

是否可以在树中选择一个节点。 False表示节点应作为扩展标题,不会触发选择事件

state

Object Optional 字符串 可选

描述节点的初始状态

state.checked

布尔值 默认值:false

是否选中一个节点,用复选框风格的图标表示

state.disabled

布尔值 默认值:false

是否禁用节点(不可选择,可扩展或可选)

state.expanded

布尔值 默认值:false

是否展开节点,即打开。 优先于全局选项水平

state.selected

布尔值 默认值:false

是否选择一个节点

tags

字符串数组 可选

与全局showTags选项一起使用可将附加信息添加到每个节点的右侧; 使用Bootstrap Badges

Extendible

您可以通过添加应用程序所需的任意数量的附加键值对来扩展节点对象。 请记住,这是在选择事件期间将被传递的对象

Options

选项允许您自定义树视图的默认外观和行为。 它们在初始化时作为对象传递给插件

//例子:初始化树视图
/ /扩大到5级
//背景颜色为绿色

$('#tree').treeview({
data: data, // data is not optional
levels: 5,
backColor: 'green'
});

您可以随时将新的选项对象传递给树视图,但是这将会重新初始化树视图

List of Options

以下是所有可用选项的列表

data

对象数组。 没有默认,期望数据

这是树视图显示的核心数据。

backColor

字符串,任何合法的颜色值。 默认值:从Bootstrap.css继承。

设置所有节点使用的默认背景色,除了在数据中以每个节点为基础重写时

borderColor

字符串,任何合法的颜色值。 默认值:从Bootstrap.css继承。

设置组件的边框颜色; 设置showBorder为false,如果你不想要一个可见的边框

checkedIcon

字符串,类名。 默认:由Bootstrap Glyphicons定义的“glyphicon glyphicon-check”

将图标设置为复选框,与showCheckbox一起使用

collapseIcon

字符串,类名称。 默认:Bootstrap Glyphicons定义的“glyphicon glyphicon-minus”

设置要在可折叠树节点上使用的图标

color

字符串,任何合法的颜色值。 默认值:从Bootstrap.css继承。

设置所有节点使用的默认前景色,除了在数据中以每个节点为基础重写时

emptyIcon

字符串,类名称。 默认:Bootstrap Glyphicons定义的“glyphicon”

设置要在没有子节点的树节点上使用的图标

enableLinks

布尔。 默认:false

是否将节点文本显示为超链接。 其数据结构中的href值必须在每个节点的基础上提供。

expandIcon

字符串,类名称。 默认:Bootstrap Glyphicons定义的“glyphicon glyphicon-plus”

设置要在可展开树节点上使用的图标

highlightSearchResults

布尔。 默认值:true

是否突出显示搜索结果

highlightSelected

布尔。 默认值:true

是否突出显示选定的节点

levels

整数。 默认:2

设置默认情况下树将被展开到深层的层次级别的数量

multiSelect

布尔。 默认:false

是否可以同时选择多个节点

nodeIcon

字符串,类名称。 默认:由Bootstrap Glyphicons定义的“glyphicon glyphicon-stop”

设置要在所有节点上使用的默认图标,除非在数据中以每个节点为基础重写

onhoverColor

字符串,任何合法的颜色值。默认:'#F5F5F5'。

设置当用户光标悬停在节点上时激活的默认背景色

selectedIcon

字符串,类名称。 默认:由Bootstrap Glyphicons定义的“glyphicon glyphicon-stop”

设置要在所有选定节点上使用的默认图标,除非在数据中的每个节点基础上重写

searchResultBackColor

字符串,任何合法的颜色值。 默认值:undefined,继承。

设置选定节点的背景颜色

searchResultColor

字符串,任何合法的颜色值。 默认:'#D9534F'。

设置选定节点的前景色

selectedBackColor

字符串,任何合法的颜色值。 默认:'#428bca'。

设置选定节点的背景颜色

selectedColor

字符串,任何合法的颜色值。 默认:'#FFFFFF'。

设置选定节点的前景色

showBorder

布尔。 默认值:true

是否在节点周围显示边框

showCheckbox

布尔。 默认:false

是否显示节点上的复选框

showIcon

布尔。 默认值:true

是否显示节点图标

showTags

布尔。 默认:false

是否在每个节点的右侧显示标签。 其值必须在每个节点的数据结构中提供

uncheckedIcon

字符串,类名。 默认:由Bootstrap Glyphicons定义的“glyphicon glyphicon-unchecked”

将图标设置为未勾选的复选框,与showCheckbox一起使用

方法

方法提供了一种以编程方式与插件交互的方式。 例如,可以通过expandNode方法扩展一个节点。

您可以通过以下两种方式之一调用方法:

1. The plugin's wrapper

插件的包装器作为访问底层方法的代理

$('#tree').treeview('methodName', args)

限制,多个参数必须作为参数数组传递

2. The treeview directly

您可以使用以下两种方法之一获取树视图的实例

//这个特殊的方法返回树视图的一个实例
$('#tree').treeview(true)
.methodName(args);

//实例也保存在DOM元素数据中,
//可以使用插件的ID“treeview”访问

$('#tree').data('treeview')
.methodName(args);

一个更好的方法,如果你计划了很多交互

List of Methods

以下是所有可用方法的列表

checkAll(options)

检查所有树节点

$('#tree').treeview('checkAll', { silent: true });

Triggers nodeChecked event; pass silent to suppress events.

checkNode(node | nodeId, options)

检查给定的树节点,接受节点或nodeId

$('#tree').treeview('checkNode', [ nodeId, { silent: true } ]);

Triggers nodeChecked event; pass silent to suppress events.

clearSearch()

清除任何先前搜索结果的树形视图,例如 删除其突出显示的状态

$('#tree').treeview('clearSearch');

Triggers searchCleared event

collapseAll(options)

折叠所有树节点,折叠整个树

$('#tree').treeview('collapseAll', { silent: true });

Triggers nodeCollapsed event; pass silent to suppress events.

collapseNode(node | nodeId, options)

折叠给定的树节点,它是子节点。 如果您不想折叠子节点,请传递选项 { ignoreChildren: true }.

$('#tree').treeview('collapseNode', [ nodeId, { silent: true, ignoreChildren: false } ]);

Triggers nodeCollapsed event; pass silent to suppress events.

disableAll(options)

禁用所有树节点

$('#tree').treeview('disableAll', { silent: true });

Triggers nodeDisabled event; pass silent to suppress events.

disableNode(node | nodeId, options)

禁用给定的树节点,接受节点或nodeId

$('#tree').treeview('disableNode', [ nodeId, { silent: true } ]);

Triggers nodeDisabled event; pass silent to suppress events.

enableAll(options)

启用所有树节点

$('#tree').treeview('enableAll', { silent: true });

Triggers nodeEnabled event; pass silent to suppress events.

enableNode(node | nodeId, options)

启用给定的树节点,接受节点或nodeId

$('#tree').treeview('enableNode', [ nodeId, { silent: true } ]);

Triggers nodeEnabled event; pass silent to suppress events.

expandAll(options)

展开所有树节点。 可以选择扩展到任何给定数量的级别

$('#tree').treeview('expandAll', { levels: 2, silent: true });

Triggers nodeExpanded event; pass silent to suppress events.

expandNode(node | nodeId, options)

展开给定的树节点,接受节点或nodeId。 可以选择扩展到任何给定数量的级别

$('#tree').treeview('expandNode', [ nodeId, { levels: 2, silent: true } ]);

Triggers nodeExpanded event; pass silent to suppress events.

getCollapsed()

返回折叠节点数组,例如 state.expanded = false

$('#tree').treeview('getCollapsed', nodeId);

getDisabled()

返回禁用的节点数组,例如 state.disabled = true

$('#tree').treeview('getDisabled', nodeId);

getEnabled()

返回已启用节点的数组,例如 state.disabled = false

$('#tree').treeview('getEnabled', nodeId);

getExpanded()

返回一个展开的节点数组,例如 state.expanded = true

$('#tree').treeview('getExpanded', nodeId);

getNode(nodeId)

返回与给定节点ID相匹配的单个节点对象.

$('#tree').treeview('getNode', nodeId);

getParent(node | nodeId)

返回给定节点的父节点,否则返回undefined

$('#tree').treeview('getParent', node);

getSelected()

返回选定节点的数组,例如 state.selected = true

$('#tree').treeview('getSelected', nodeId);

getSiblings(node | nodeId)

返回给定节点的兄弟节点数组,如果有效则返回undefined

$('#tree').treeview('getSiblings', node);

getUnselected()

返回未选定节点的数组,例如 state.selected = false

$('#tree').treeview('getUnselected', nodeId);

remove()

删除树视图组件。 删除附加事件,内部附加对象和添加的HTML元素

$('#tree').treeview('remove');

revealNode(node | nodeId, options)

显示给定的树节点,将树从节点扩展到根

$('#tree').treeview('revealNode', [ nodeId, { silent: true } ]);

Triggers nodeExpanded event; pass silent to suppress events.

search(pattern, options)

在树视图中搜索与给定字符串匹配的节点,并在树中突出显示它们。

返回匹配节点的数组

$('#tree').treeview('search', [ 'Parent', {
ignoreCase: true, // case insensitive
exactMatch: false, // like or equals
revealResults: true, // reveal matching nodes
}]);

Triggers searchComplete event

selectNode(node | nodeId, options)

选择给定的树节点,接受节点或nodeId

$('#tree').treeview('selectNode', [ nodeId, { silent: true } ]);

Triggers nodeSelected event; pass silent to suppress events.

toggleNodeChecked(node | nodeId, options)

切换节点检查状态; 检查是否未选中,如果选中取消选中

$('#tree').treeview('toggleNodeChecked', [ nodeId, { silent: true } ]);

Triggers either nodeChecked or nodeUnchecked event; pass silent to suppress events.

toggleNodeDisabled(node | nodeId, options)

切换节点禁用状态; 禁用如果启用,启用如果禁用

$('#tree').treeview('toggleNodeDisabled', [ nodeId, { silent: true } ]);

Triggers either nodeDisabled or nodeEnabled event; pass silent to suppress events.

toggleNodeExpanded(node | nodeId, options)

切换节点展开状态; 如果展开则折叠,如果折叠则展开

$('#tree').treeview('toggleNodeExpanded', [ nodeId, { silent: true } ]);

Triggers either nodeExpanded or nodeCollapsed event; pass silent to suppress events.

toggleNodeSelected(node | nodeId, options)

切换节点选择状态; 选择是否取消选择,取消选择

$('#tree').treeview('toggleNodeSelected', [ nodeId, { silent: true } ]);

Triggers either nodeSelected or nodeUnselected event; pass silent to suppress events.

uncheckAll(options)

取消选中所有的树节点

$('#tree').treeview('uncheckAll', { silent: true });

Triggers nodeUnchecked event; pass silent to suppress events.

uncheckNode(node | nodeId, options)

取消给定的树节点,接受节点或nodeId

$('#tree').treeview('uncheckNode', [ nodeId, { silent: true } ]);

Triggers nodeUnchecked event; pass silent to suppress events.

unselectNode(node | nodeId, options)

取消选择给定的树节点,接受节点或nodeId

$('#tree').treeview('unselectNode', [ nodeId, { silent: true } ]);

Triggers nodeUnselected event; pass silent to suppress events.

Events 事件

提供事件以便您的应用程序可以响应树视图状态中的更改。 例如,如果要在选择节点时更新显示,请使用nodeSelected事件。

您可以通过使用选项回调处理程序或标准jQuery .on方法来绑定到以下定义的任何事件。

使用选项回调处理程序的示例:

$('#tree').treeview({

//回调的命名约定是用`on`预先设置的
   //并大写事件名称的第一个字母
   //例如 nodeSelected - > onNodeSelected

  onNodeSelected: function(event, data) {
// Your logic goes here
});

并使用jQuery .on方法

$('#tree').on('nodeSelected', function(event, data) {
// Your logic goes here
});

List of Events

nodeChecked (event, node) - 节点被选中

nodeCollapsed (event, node) - 节点已折叠

nodeDisabled (event, node) -一个节点被禁用

nodeEnabled (event, node) - 节点已启用

nodeExpanded (event, node) - 节点被展开

nodeSelected (event, node) - 节点被选中

nodeUnchecked (event, node) - 一个节点没有被选中

nodeUnselected (event, node) - 节点未被选中

searchComplete (event, results) - 搜索完成后

searchCleared (event, results) - 搜索结果被清除后

 


Bootstrap-treeView 实际操作总结的更多相关文章

  1. Bootstrap treeview增加或者删除节点

    参考(AddNode: http://blog.csdn.net/qq_25628235/article/details/51719917,deleteNode:http://blog.csdn.ne ...

  2. 初始化bootstrap treeview树节点

    最近在做启明星图库时,使用了Jquery Bootstrap  Treeview插件.但是,遇到了一个初始化的问题.先看效果如下: 当用户打开图库时,左边分类第一个类别是“所有分类”,默认需要选中. ...

  3. BootStrap TreeView使用示例

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  4. bootstrap treeview 树形数据生成

    这个问题还是挺经典的,后台只是负责查出所有的数据,前台js来处理数据展示给treeview;show you the code below:<script> $(function () { ...

  5. bootstrap treeview实现菜单树

    本博客,介绍通过Bootstrap的treeview插件实现菜单树的功能. treeview链接:http://www.htmleaf.com/Demo/201502141380.html ORM框架 ...

  6. bootstrap之鼠标操作

    TouchLongClick package io.appium.android.bootstrap.handler; import android.os.SystemClock; import co ...

  7. bootstrap table编辑操作的时候 在模态框里加载iframe页面(加载的页面是在另一个页面做编辑)的时候如何关闭模态框和刷新table

    //关闭模态框                             window.parent.$('#myModal').modal('hide'); //修改成功后刷新table表格      ...

  8. TreeView和ListView数据库查询数据联动操作

    好久不用了,重新整理下放这里以备需要使用,功能见图 数据库表结构 定义TreeView addObject中data存储的记录集 type PNode = ^TNode; TNode = record ...

  9. Web前端学习笔记:Bootstrap框架

    很久之前就有很多人给我推荐twitter的Bootstrap框架,但是直到前几天我才真正学习了下Bootstrap,的确是相当棒的框架,至少从视觉体验上超越了很多以前碰到了前端UI框架.今天我要聊聊B ...

  10. bootstrap table使用小记

    bootstrap table是一个非常不错的,基于bootstrap的插件,它扩展和丰富了bootstrap表格的操作,如格式化表格,表格选择器,表格工具栏,分页等等. 最近基于bootstrap开 ...

随机推荐

  1. 06. redis cluster

    目录 Redis Cluster redis cluster 特点 搭建redis cluster 访问redis cluster redis-cli 访问redis cluster 重新分片数据 新 ...

  2. Sigmoid函数与Softmax函数的理解

    1. Sigmod 函数 1.1 函数性质以及优点 其实logistic函数也就是经常说的sigmoid函数,它的几何形状也就是一条sigmoid曲线(S型曲线).               其中z ...

  3. Java精通并发-Condition编程模式详解与分析

    继续上一次https://www.cnblogs.com/webor2006/p/11890688.html的Condition接口说明进行阅读: 上面这个程序会在之后手动来实现一下,说实话这种写法在 ...

  4. LCD编程_简单测试

    首先,需要编写一个led_test.c的文件,依据代码框架,在led_test.c中我们能够看到的只是led.c.我们是看不到led_controller.c的.比如说,在led_test.c中,需要 ...

  5. windows 运行库与dll文件

    Windows 10包含版本 win10家庭版win10专业版win10教育版win 10企业版 Windows 7包含6个版本分别为Windows 7 Starter(初级版)Windows 7 H ...

  6. VMware下安装Ubuntu虚拟机

    ubuntu系统是以桌面应用为主的.当下最火的linux操作系统,具有实用的界面,并且完全免费. 在Ubuntu的 Linux 世界里,已经不再只是简陋的界面+命令行,而是一款华丽时尚且无比实用的操作 ...

  7. winform解决方案资源管理器

  8. webpack中路径的理解

    webpack 前端打包工具, 开发人员要面对的路径主要是: 打包前的路径(开发环境路径)和打包后的路径(生产环境路径) 在webpack.config.js中配置的output.path, outp ...

  9. 请指出document load和document ready的区别

    document load文档的所有内容都加载完成 document ready文档的DOM加载完成

  10. C++ 派生类覆盖重载基类函数

    派生类希望基类重载函数可见,情况有三种: a)派生类中覆盖某个版本,则某个版本可见,全部都覆盖重写,则全部版本可见. b)派生类中一个也不覆盖,则全部基类版本可见. c)派生类需要添加新的重载版本,同 ...