三级联动

2018-07-02  本文已影响0人  Augenstern___
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <title>HTML5手机端三级联动城市选择代码</title>
    <link rel="stylesheet" type="text/css" href="css/demo.css">
<style>
</style>
</head>
<body>
<div class="container">

<div class="row main" style="margin-top:30px;">
    <div class="col-md-12">
        <div class="row" style="line-height: 36px; text-align: center;font-size:18px;">
                <a href="#" class="btn btn-info btn-lg active" role="button" id="sel_city">点击选取省市区县</a>
        </div>

    </div>
</div>

</div>
<script src="js/picker.min.js"></script>
<script src="js/city.js"></script>
<script>
var nameEl = document.getElementById('sel_city');

var first = []; /* 省,直辖市 */
var second = []; /* 市 */
var third = []; /* 镇 */

var selectedIndex = [0, 0, 0]; /* 默认选中的地区 */

var checked = [0, 0, 0]; /* 已选选项 */

function creatList(obj, list){
  obj.forEach(function(item, index, arr){
  var temp = new Object();
  temp.text = item.name;
  temp.value = index;
  list.push(temp);
  })
}
creatList(city, first);
if (city[selectedIndex[0]].hasOwnProperty('sub')) {
  creatList(city[selectedIndex[0]].sub, second);
} else {
  second = [{text: '', value: 0}];
}

if (city[selectedIndex[0]].sub[selectedIndex[1]].hasOwnProperty('sub')) {
  creatList(city[selectedIndex[0]].sub[selectedIndex[1]].sub, third);
} else {
  third = [{text: '', value: 0}];
}

  var picker = new Picker({
data: [first, second, third],
  selectedIndex: selectedIndex,
title: '地址选择'
});

    picker.on('picker.select', function (selectedVal, selectedIndex) {
  var text1 = first[selectedIndex[0]].text;
  var text2 = second[selectedIndex[1]].text;
  var text3 = third[selectedIndex[2]] ? third[selectedIndex[2]].text : '';

nameEl.innerText = text1 + ' ' + text2 + ' ' + text3;
});

picker.on('picker.change', function (index, selectedIndex) {
  if (index === 0){
firstChange();
  } else if (index === 1) {
secondChange();
  }

function firstChange() {
second = [];
third = [];
checked[0] = selectedIndex;
var firstCity = city[selectedIndex];
if (firstCity.hasOwnProperty('sub')) {
  creatList(firstCity.sub, second);

  var secondCity = city[selectedIndex].sub[0]
  if (secondCity.hasOwnProperty('sub')) {
    creatList(secondCity.sub, third);
  } else {
    third = [{text: '', value: 0}];
    checked[2] = 0;
  }
} else {
  second = [{text: '', value: 0}];
  third = [{text: '', value: 0}];
  checked[1] = 0;
  checked[2] = 0;
      }

picker.refillColumn(1, second);
picker.refillColumn(2, third);
picker.scrollColumn(1, 0)
picker.scrollColumn(2, 0)
  }

  function secondChange() {
third = [];
checked[1] = selectedIndex;
var first_index = checked[0];
if (city[first_index].sub[selectedIndex].hasOwnProperty('sub')) {
  var secondCity = city[first_index].sub[selectedIndex];
  creatList(secondCity.sub, third);
  picker.refillColumn(2, third);
  picker.scrollColumn(2, 0)
} else {
  third = [{text: '', value: 0}];
  checked[2] = 0;
  picker.refillColumn(2, third);
  picker.scrollColumn(2, 0)
}
  }

});

picker.on('picker.valuechange', function (selectedVal, selectedIndex) {
  console.log(selectedVal);
  console.log(selectedIndex);
});

nameEl.addEventListener('click', function () {
    picker.show();
});
</script>
</body>
</html>
上一篇下一篇

猜你喜欢

热点阅读