AngularJS中实现无限级联动菜单(使用demo)

原文地址:http://www.cnblogs.com/front-end-ralph/p/5133122.html

昨天没来得及贴几个使用demo,今天补上,供有兴趣的同学参考 :)

1. 同步加载子选项demo
2. 异步加载子选项demo
3. 初始值回填demo
4. 倒金字塔依赖demo

directive的源代码请移步上一个帖子:
http://www.cnblogs.com/front-end-ralph/p/5131687.html

1. 同步加载子选项
在各联动菜单加载之前,我们已经通过某种方式(比如后端渲染、api依赖、deferred依赖等等)拿到了渲染各级菜单所需的各种数据,我们只需要将该数据处理为
[{
text: ‘some text‘,
value: ‘some value‘
},]
的形式,并封装成数据源函数即可。以省-市联动为例:
html部分:
注意第二个select中声明了dependents="province",以此实现联动

<select multi-level-select source="getProvinces" name="province" ng-model="form.province" empty="请选择省份"></select>
<select multi-level-select source="getCities" name="city" ng-model="form.city" empty="请选择城市" dependents="province"></select>

controller部分:
预处理数据,提供数据源函数

controller(‘myCtrl‘, [‘$scope‘, function ($scope) {

    // angular使用好习惯,将primitive值放到对象上
    var form = {};
    $scope.form = form;

    var data = [{
        name: ‘浙江‘,
        id: 10,
        cities: [{
            name: ‘杭州‘,
            id: 100
        }, {
            name: ‘宁波‘,
            id: 101
        }, {
            name: ‘温州‘,
            id: 102
        }]
    }, {
        name: ‘广东‘,
        id: 20,
        cities: [{
            name: ‘广州‘,
            id: 200
        }, {
            name: ‘深圳‘,
            id: 201
        }, {
            name: ‘佛山‘,
            id: 202
        }]
    }, {
        name: ‘山东‘,
        id: 30,
        cities: [{
            name: ‘济南‘,
            id: 301
        }, {
            name: ‘青岛‘,
            id: 302
        }, {
            name: ‘烟台‘,
            id: 303
        }]
    }];

    var provinces = [];

    var citiesLookup = {};

    // 预处理,返回[{text: ‘some text‘, value: ‘some value‘},]的数据格式
    $.each(data, function (index, province) {
        provinces.push({
            text: province.name,
            value: province.id
        });
        var cities = [];
        $.each(province.cities, function (index, city) {
            cities.push({
                text: city.name,
                value: city.id
            });
        });
        citiesLookup[province.id] = cities;
    });

    $scope.getProvinces = function () {
        return provinces;
    };

    $scope.getCities = function (values) {
        return citiesLookup[values.province] || [];
    };

}]);

2. 异步加载子选项demo
主要差异是数据源函数应该返回promise实例(AngularJS中使用$q即可)。为了演示方便,这里就不用$http了,除了预处理(由使用者自己的业务逻辑负责)外,完全一样。
和上一个例子非常相似,只需要将两个数据源函数修改为:

$scope.getProvinces = function () {
    return $q(function (resolve) {
        // 异步时应返回promise,这里就不用http了,除了预处理(由使用者自己的业务逻辑负责)外,完全一样
        // 如果需要缓存,也请在这里自己负责
        $timeout(function () {
            resolve(provinces);
        }, 100);
    });
};

$scope.getCities = function (values) {
    return $q(function (resolve) {
        $timeout(function () {
            resolve(citiesLookup[values.province] || []);
        }, 100);
    });
};

3. 初始值回填
因为在开发初期这个需求就很明确了,所以使用上不需要做额外的工作,如果有初始值,只需要在controller中为其赋值即可:

// angular使用好习惯,将primitive值放到对象上
var form = {};
$scope.form = form;
form.province = 30;
form.city = 301;

4. 倒金子塔依赖
依赖声明是通过由逗号分割的字符串的形式完成的,使用上非常方便。
设想以下的场景:
教务处需要学生对课程进行评价,学生先选择周几,再选择时间,然后再选择具体的课程下拉框
周几和时间之间互不依赖,课程下拉框同时依赖于周几和时间,换言之,一旦周几和时间中的任意一个改变,课程下拉框就应该更新。
html部分:
注意第三个select的dependents属性是day,hour,即同时依赖于day和hour

<select multi-level-select source="getDays" name="day" ng-model="form.day" empty="请选择周几"></select>
<select multi-level-select source="getHours" name="hour" ng-model="form.hour" empty="请选择时间"></select>
<select multi-level-select source="getCourses" name="course" ng-model="form.course" empty="请选择课程" dependents="day,hour"></select>

controller部分:
和前面的例子类似,没有什么特殊的,预处理数据并提供数据源函数即可。

controller(‘myCtrl‘, function ($scope) {

    var form = {};
    $scope.form = form;

    $scope.getDays = function () {
        var days = ‘一二三‘.split(‘‘);
        days.forEach(function (item, index) {
            days[index] = {
                text: ‘星期‘ + item,
                value: ‘星期‘ + item
            };
        });
        return days;
    };

    $scope.getHours = function () {
        return [{
            text: ‘09:00-12:00‘,
            value: ‘1‘
        }, {
            text: ‘14:00-17:00‘,
            value: ‘2‘
        }];
    };

    var courses = {
        ‘星期一‘: {
            ‘1‘: [{
                value: ‘数学‘,
                text: ‘数学‘
            }, {
                value: ‘精读‘,
                text: ‘精读‘
            }],
            ‘2‘: [{
                value: ‘足球‘,
                text: ‘足球‘
            }]
        },
        ‘星期二‘: {
            ‘1‘: [{
                value: ‘听力‘,
                text: ‘听力‘
            }],
            ‘2‘: [{
                value: ‘数学‘,
                text: ‘数学‘
            }]
        },
        ‘星期三‘: {
            ‘1‘: [{
                value: ‘计算机‘,
                text: ‘计算机‘
            }],
            ‘2‘: [{
                value: ‘游泳‘,
                text: ‘游泳‘
            }, {
                value: ‘古汉语‘,
                text: ‘古汉语‘
            }]
        },
    };

    $scope.getCourses = function (values) {
        if (!values.day || !values.hour) {
            return [];
        }
        return courses[values.day][values.hour];
    };
});
时间: 2024-08-06 02:45:14

AngularJS中实现无限级联动菜单(使用demo)的相关文章

利用多叉树实现Ext JS中的无限级树形菜单(一种构建多级有序树形结构JSON的方法)

一.问题研究的背景和意义 目前在Web应用程序开发领域,Ext JS框架已经逐渐被广泛使用,它是富客户端开发中出类拔萃的框架之一.在Ext的UI控件中,树形控件无疑是最为常用的控件之一,它用来实现树形结构的菜单.TreeNode用来实现静态的树形菜单,AsyncTreeNode用来实现动态的异步加载树形菜单,后者最为常用,它通过接收服务器端返回来的JSON格式的数据,动态生成树形菜单节点.动态生成树有两种思路:一种是一次性生成全部树节点,另一种是逐级加载树节点(利用AJAX,每次点击节点时查询下

开发一个jQuery插件——多级联动菜单

引言 开发中,有好多地方用到联动菜单,以前每次遇到联动菜单的时候都去重新写,代码重用率很低,前几天又遇到联动菜单的问题,总结了下,发现可以开发一个联动菜单的功能,以后想用的时候就方便多了.项目中每个页面都有引用jQuery,,开发个jQuery联动菜单插件,说动手就动手,下面跟大家分享分享. 我用的jQuery插件方式 (function($){ $.fn.casmenu=function(argvs){ //your code } })(jQuery); 其中jQuery传入的是jquery对

java桌面程序中使用联动菜单遇到与解决的问题

最近在做一个小小的系统,想实现联动菜单,故尝试了几种方法. 1.想通过一个线程来监控下拉菜单的变化,从而控制从菜单. 遇到的问题: ①:开始,我是用一个外部线程类,不过我要通过外部线程类来改变主窗口的下拉菜单, ②:所以,就需要一个传递一个类参数才能引用, ③:我在主窗口中调用线程类. ④:由于我需要把从数据中得来的数据在线程类中使用,所以就需要在线程类中使用数据库连接 当然不是在run方法中使用,而是在最开始定义数据时就初始化赋值好. ⑤:我以为,在最开始使用数据库连接,就连一次,应该没事.

AngularJS中Scope间通讯Demo

在AngularJS中,每一个controller都有对应的Scope,而Scope间有时候需要通讯.比如有如下的一个controller嵌套: <body ng-controller="AppCtrl"> <table ng-controller = "ProductCtrl"> ... <tr ng-repeat="product in products"> <td>{{$index + 1}}

[ PHP+jQuery ] ajax 多级联动菜单的应用:电商网站的用户地址选择功能 ( 一 ) - 传统下拉菜单

/** jQuery version: 1.8.3 Author: 小dee Date: 2014.11.5 */ 说明:分析其他网站的图片较多,可以在目录跳过直接看本文 demo . 目录: 其他网站分析 亚马逊 淘宝 京东 当当 本文案例 demo1 demo2 [ 后面的博文再写 ] demo3 [ 后面的博文再写 ] 惯例,先看看他山之石,选择了四家比较大的电商网站:亚马逊.淘宝.京东.当当,看看它们的地址联动菜单是怎么做的. 1. 亚马逊[返回目录][下一节:淘宝] 图1 默认界面 说

转: javascript实现全国城市三级联动菜单代码

<html> <head> <title>js全国城市三级联动菜单代码_B5教程网</title> <meta http-equiv="Content-Type" content="text/html; charset=gb2312"> <script LANGUAGE="JavaScript"> function Dsy() { this.Items = {}; } Dsy

AngularJS 中 Controller 之间的通信

用 Angular 进行开发,基本上都会遇到 Controller 之间通信的问题,本文对此进行一个总结. 在 Angular 中,Controller 之间通信的方式主要有三种: 1)作用域继承.利用子 Controller 控制父 Controller 上的数据.(父 Controller 中的数据要为引用类型,不能是基本类型,原因参见 AngularJS中的作用域 一文) 2)注入服务.把需要共享的数据注册为一个 service,在需要的 Controller 中注入. 3)基于事件.利用

地区联动菜单

<html> <head> <title>-www.51windows.Net</title> <meta http-equiv="Content-Type" content="text/html; charset=gb2312"> <style> <!-- body { font-size: 14px } --> </style> </head> <b

项目实战之FORM、联动菜单组件的实现

联动菜单也是我们常用功能之间,下面描述一下联动菜单的一种实现. 一.功能描述:两级联动. 在选择了集群中一项后,会将该集群下的key值都关联出来.开发时在这里遇到一个问题,卡了很久.遇到的问题:在上图的状态下,更换一级联动的值,二级联动的值依然会保留上一次的值.其实这个问题挺简单的.就是在加载二级联动值时先清除.重点还是在对ant的组件不了解,不会使用. 二.功能代码 import React from 'react'; import '../index.less'; import {Form,