基于AngularJs 省市区联动实践

HTML:

<city-linkage city-list=division></city-linkage>

controller

		$scope.division =  $localStorage.division;
		$scope.$on('cityVlue', function(e, v) {
                    		console.log(v);
               	 });

directive HTML

<div class="cityLinkage" class="container-fluid">
    <div class="row">
        <label class="col-md-2 control-label" style="max-width:140px;">
            所属区域:
        </label>
        <div class="col-md-10">
            <select  class="col-md-3" style="max-width:160px;" ng-model="address.province" ng-options="key as key for (key,value) in cityList"
                ng-change="address.city='';address.district='';">
                <option value="">省</option>
            </select>
            <select class="col-md-3" style="max-width:160px;" ng-model="address.city" ng-options="key as key for (key,value) in cityList[address.province]"
                ng-change="address.district='';">
                <option value="">市</option>
            </select>
            <select class="col-md-3" style="max-width:160px;" ng-model="address.district" ng-options="value as value for value in cityList[address.province][address.city]" ng-change="emitCityValue();">
                <option value="">区</option>
            </select>
        </div>
        
    </div>
</div>

directive Controller

require('./cityLinkage.scss');
define(['../directivesModule'], function(module) {
    module.directive("cityLinkage", [function() {
        'use strict';
        return {
            restrict: 'E',
            templateUrl: 'cityLinkage.html',
            replace: true,
            scope: {
                cityList: '='
            },
            controller: function($scope, $element, $state) {
                
                $scope.emitCityValue = function () {
                    $scope.$emit('cityVlue', {'province': $scope.address.province, 'city': $scope.address.city, 'district': $scope.address.district});
                }

            },
            link: function(scope, ele, attrs) {
               
                // console.log(scope.cityList);
                
        
            }

        };
    }])
});


数据

$scope.division = { "北京市": { "北京市": ["东城区""西城区""崇文区""宣武区""朝阳区""丰台区""石景山区""海淀区""门头沟区""房山区""通州区""顺义区""昌平区""大兴区""怀柔区""平谷区""密云县""延庆县"]}, "上海市": { "上海市": ["黄浦区""卢湾区""徐汇区""长宁区""静安区""普陀区""闸北区""虹口区""杨浦区""闵行区""宝山区""嘉定区""浦东新区""金山区""松江区""青浦区""南汇区""奉贤区""崇明县"]}, "天津市": { "天津市": ["和平区""河东区""河西区""南开区""河北区""红桥区""塘沽区""汉沽区""大港区""东丽区""西青区""津南区""北辰区""武清区""宝坻区""宁河县""静海县""蓟县"]}, "重庆市": { "重庆市": ["万州区""涪陵区""渝中区""大渡口区""江北区""沙坪坝区""九龙坡区""南岸区""北碚区""万盛区""双桥区""渝北区""巴南区""黔江区""长寿区""綦江县""潼南县""铜梁县""大足县""荣昌县""璧山县""梁平县""城口县""丰都县""垫江县""武隆县""忠县""开县""云阳县""奉节县""巫山县""巫溪县""石柱土家族自治县""秀山土家族苗族自治县""酉阳土家族苗族自治县""彭水苗族土家族自治县""江津市""合川市""永川市""南川市"]}, "四川省": { "成都市": ["锦江区""青羊区""金牛区""武侯区""成华区""龙泉驿区""青白江区""新都区""温江县""金堂县""双流县""郫县""大邑县""蒲江县""新津县""都江堰市""彭州市""邛崃市""崇州市"], "自贡市": ["自流井区""贡井区""大安区""沿滩区""荣县""富顺县"], "攀枝花市": ["东区""西区""仁和区""米易县""盐边县"], "泸州市": ["江阳区""纳溪区""龙马潭区""泸县""合江县""叙永县""古蔺县"], "德阳市": ["旌阳区""中江县""罗江县""广汉市""什邡市""绵竹市"], "绵阳市": ["涪城区""游仙区""三台县""盐亭县""安县""梓潼县""北川羌族自治县""平武县""江油市"], "广元市": ["市中区""元坝区""朝天区""旺苍县""青川县""剑阁县""苍溪县"], "遂宁市": ["船山区""安居区""蓬溪县""射洪县""大英县"], "内江市": ["市中区""东兴区""威远县""资中县""隆昌县"], "乐山市": ["市中区""沙湾区""五通桥区""金口河区""犍为县""井研县""夹江县""沐川县""峨边彝族自治县""马边彝族自治县""峨眉山市"], "南充市": ["顺庆区""高坪区""嘉陵区""南部县""营山县""蓬安县""仪陇县""西充县""阆中市"], "眉山市": ["东坡区""仁寿县""彭山县""洪雅县""丹棱县""青神县"], "宜宾市": ["翠屏区""宜宾县""南溪县""江安县""长宁县""高县""珙县""筠连县""兴文县""屏山县"], "广安市": ["广安区""岳池县""武胜县""邻水县""华莹市"], "达州市": ["通川区""达县""宣汉县""开江县""大竹县""渠县""万源市"], "雅安市": ["雨城区""名山县""荥经县""汉源县""石棉县""天全县""芦山县""宝兴县"], "巴中市": ["巴州区""通江县""南江县""平昌县"], "资阳市": ["雁江区""安岳县""乐至县""简阳市"], "阿坝藏族羌族自治州": ["汶川县""理县""茂县""松潘县""九寨沟县""金川县""小金县""黑水县""马尔康县""壤塘县""阿坝县""若尔盖县""红原县"], "甘孜藏族自治州": ["康定县""泸定县""丹巴县""九龙县""雅江县""道孚县""炉霍县""甘孜县""新龙县""德格县""白玉县""石渠县""色达县""理塘县""巴塘县""乡城县""稻城县""得荣县"], "凉山彝族自治州": ["西昌市""木里藏族自治县""盐源县""德昌县""会理县""会东县""宁南县""普格县""布拖县""金阳县""昭觉县""喜德县""冕宁县""越西县""甘洛县""美姑县""雷波县"]}, "贵州省": { "贵阳市": ["南明区""云岩区""花溪区""乌当区""白云区""小河区""开阳县""息烽县""修文县""清镇市"], "六盘水市": ["钟山区""六枝特区""水城县""盘县"], "遵义市": ["红花岗区""汇川区""遵义县""桐梓县""绥阳县""正安县""道真仡佬族苗族自治县""务川仡佬族苗族自治县""凤冈县""湄潭县""余庆县""习水县""赤水市""仁怀市"], "安顺市": ["西秀区""平坝县""普定县""镇宁布依族苗族自治县""关岭布依族苗族自治县""紫云苗族布依族自治县"], "铜仁地区": ["铜仁市""江口县""玉屏侗族自治县""石阡县""思南县""印江土家族苗族自治县""德江县""沿河土家族自治县""松桃苗族自治县""万山特区"], "黔西南布依族苗族自治州": ["兴义市""兴仁县""普安县""晴隆县""贞丰县""望谟县""册亨县""安龙县"], "毕节地区": ["毕节市""大方县""黔西县""金沙县""织金县""纳雍县""威宁彝族回族苗族自治县""赫章县"], "黔东南苗族侗族自治州": ["凯里市""黄平县""施秉县""三穗县""镇远县""岑巩县""天柱县""锦屏县""剑河县""台江县""黎平县""榕江县""从江县""雷山县""麻江县""丹寨县"], "黔南布依族苗族自治州": ["都匀市""福泉市""荔波县""贵定县""瓮安县""独山县""平塘县""罗甸县""长顺县""龙里县""惠水县""三都水族自治县"]}, "云南省": { "昆明市": ["五华区""盘龙区""官渡区""西山区""东川区""呈贡县""晋宁县""富民县""宜良县""石林彝族自治县""嵩明县""禄劝彝族苗族自治县""寻甸回族彝族自治县""安宁市"], "曲靖市": ["麒麟区""马龙县""陆良县""师宗县""罗平县""富源县""会泽县""沾益县""宣威市"], "玉溪市": ["红塔区""江川县""澄江县""通海县""华宁县""易门县""峨山彝族自治县""新平彝族傣族自治县""元江哈尼族彝族傣族自治县"], "保山市": ["隆阳区""施甸县""腾冲县""龙陵县""昌宁县"], "昭通市": ["昭阳区""鲁甸县""巧家县""盐津县""大关县""永善县""绥江县""镇雄县""彝良县""威信县""水富县"], "丽江市": ["古城区""玉龙纳西族自治县""永胜县""华坪县""宁蒗彝族自治县"], "思茅市": ["翠云区""普洱哈尼族彝族自治县""墨江哈尼族自治县""景东彝族自治县""景谷傣族彝族自治县""镇沅彝族哈尼族拉祜族自治县""江城哈尼族彝族自治县""孟连傣族拉祜族佤族自治县""澜沧拉祜族自治县""西盟佤族自治县"], "临沧市": ["临翔区""凤庆县""云县""永德县""镇康县""双江拉祜族佤族布朗族傣族自治县""耿马傣族佤族自治县""沧源佤族自治县"], "楚雄彝族自治州": ["楚雄市""双柏县""牟定县""南华县""姚安县""大姚县""永仁县""元谋县""武定县""禄丰县"], "红河哈尼族彝族自治州": ["个旧市""开远市""蒙自县""屏边苗族自治县""建水县""石屏县""弥勒县""泸西县""元阳县""红河县""金平苗族瑶族傣族自治县""绿春县""河口瑶族自治县"], "文山壮族苗族自治州": ["文山县""砚山县""西畴县""麻栗坡县""马关县""丘北县""广南县""富宁县"], "西双版纳傣族自治州": ["景洪市""勐海县""勐腊县"], "大理白族自治州": ["大理市""漾濞彝族自治县""祥云县""宾川县""弥渡县""南涧彝族自治县""巍山彝族回族自治县""永平县""云龙县""洱源县""剑川县""鹤庆县"], "德宏傣族景颇族自治州": ["瑞丽市""潞西市""梁河县""盈江县""陇川县"], "怒江傈僳族自治州": ["泸水县""福贡县""贡山独龙族怒族自治县""兰坪白族普米族自治县"], "迪庆藏族自治州": ["香格里拉县""德钦县""维西傈僳族自治县"]}, "西藏省": { "拉萨市": ["城关区""林周县""当雄县""尼木县""曲水县""堆龙德庆县""达孜县""墨竹工卡县"], "昌都地区": ["昌都县""江达县""贡觉县""类乌齐县""丁青县""察雅县""八宿县""左贡县""芒康县""洛隆县""边坝县"], "山南地区": ["乃东县""扎囊县""贡嘎县""桑日县""琼结县""曲松县""措美县""洛扎县""加查县""隆子县""错那县""浪卡子县"], "日喀则地区": ["日喀则市""南木林县""江孜县""定日县""萨迦县""拉孜县""昂仁县""谢通门县""白朗县""仁布县""康马县""定结县""仲巴县""亚东县""吉隆县""聂拉木县""萨嘎县""岗巴县"], "那曲地区": ["那曲县""嘉黎县""比如县""聂荣县""安多县""申扎县""索县""班戈县""巴青县""尼玛县"], "阿里地区": ["普兰县""札达县""噶尔县""日土县""革吉县""改则县""措勤县"], "林芝地区": ["林芝县""工布江达县""米林县""墨脱县""波密县""察隅县""朗县"]}, "河南省": { "郑州市": ["中原区""二七区""管城回族区""金水区""上街区""邙山区"

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值