全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

Angular.JS实现无限级的联动菜单(使用demo)

前言

之前给大家介绍过一篇关于AngularJS中实现无限级联动菜单的文章,但没来得及和大家分享使用的示例,下面这篇文章就来给大家分享下几个使用的demo。

文中包括demo如下:

1. 同步加载子选项demo

2. 异步加载子选项demo

3. 初始值回填demo

4. 倒金字塔依赖demo

注意:在阅读本文前请先移步上一篇文章:https://www./article/78126.htm

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];
 };
});

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。


# angularjs  # 无限级菜单  # 联动菜单  # angular  # AngularJS实现树形结构(ztree)菜单示例代码  # 实例详解AngularJS实现无限级联动菜单  # AngularJS折叠菜单实现方法示例  # AngularJS实现的select二级联动下拉菜单功能示例  # Angular.js与Bootstrap相结合实现手风琴菜单代码  # AngularJS动态菜单操作指令  # AngularJS+Bootstrap3多级导航菜单的实现代码  # AngularJS模糊查询功能实现代码(过滤内容下拉菜单排序过滤敏感字符验证判断后添加表格信息)  # angularjs+bootstrap菜单的使用示例代码  # Angluar+zorro实现无限级菜单  # 请选择  # 加载  # 自己的  # 只需  # 给大家  # 这篇文章  # 下拉框  # 几个  # 在这里  # 古汉语  # 烟台  # 佛山  # 依赖于  # 要在  # 所需  # 没有什么  # 请先  # 上一  # 要做  # 济南 


相关文章: 如何通过VPS建站实现广告与增值服务盈利?  高防服务器租用指南:配置选择与快速部署攻略  教程网站设计制作软件,怎么创建自己的一个网站?  微信小程序制作网站有哪些,微信小程序需要做网站吗?  建站之星安装后如何配置SEO及设计样式?  专业企业网站设计制作公司,如何理解商贸企业的统一配送和分销网络建设?  全景视频制作网站有哪些,全景图怎么做成网页?  海南网站制作公司有哪些,海口网是哪家的?  大连企业网站制作公司,大连2025企业社保缴费网上缴费流程?  如何零基础在云服务器搭建WordPress站点?  网站专业制作公司有哪些,做一个公司网站要多少钱?  宝华建站服务条款解析:五站合一功能与SEO优化设置指南  怎么用手机制作网站链接,dw怎么把手机适应页面变成网页?  建站之星各版本价格是多少?  如何在宝塔面板中创建新站点?  无锡营销型网站制作公司,无锡网选车牌流程?  高防服务器如何保障网站安全无虞?  制作网页的网站有哪些,电脑上怎么做网页?  网站设计制作书签怎么做,怎样将网页添加到书签/主页书签/桌面?  成都网站制作报价公司,成都工业用气开户费用?  浅谈Javascript中的Label语句  如何快速建站并高效导出源代码?  常州自助建站:操作简便模板丰富,企业个人快速搭建网站  建站之星如何助力网站排名飙升?揭秘高效技巧  邀请函制作网站有哪些,有没有做年会邀请函的网站啊?在线制作,模板很多的那种?  如何在阿里云购买域名并搭建网站?  如何通过二级域名建站提升品牌影响力?  建站主机如何选?高性价比方案全解析  如何通过可视化优化提升建站效果?  建站之星如何助力企业快速打造五合一网站?  简易网站制作视频教程,使用记事本编写一个简单的网页html文件?  如何在阿里云虚拟服务器快速搭建网站?  宝塔面板如何快速创建新站点?  ,有什么在线背英语单词效率比较高的网站?  建站主机SSH密钥生成步骤及常见问题解答?  建站之星安装后如何自定义网站颜色与字体?  网站网页制作电话怎么打,怎样安装和使用钉钉软件免费打电话?  安云自助建站系统如何快速提升SEO排名?  建站之星手机一键生成:多端自适应+小程序开发快速建站指南  ,交易猫的商品怎么发布到网站上去?  建站之星安装提示数据库无法连接如何解决?  GML (Geography Markup Language)是什么,它如何用XML来表示地理空间信息?  重庆市网站制作公司,重庆招聘网站哪个好?  小型网站制作HTML,*游戏网站怎么搭建?  如何在阿里云虚拟主机上快速搭建个人网站?  打鱼网站制作软件,波克捕鱼官方号怎么注册?  深圳网站制作的公司有哪些,dido官方网站?  香港服务器租用每月最低只需15元?  武汉网站如何制作,黄黄高铁武穴北站途经哪些村庄?  如何零成本快速生成个人自助网站? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。