如何使用 jquery/javascript 重置选择的 class li 元素

How to reset chosen class li elements using jquery/javascript

我需要一些帮助。我需要再次重置所有由 chosen-select jQuery 插件自动创建的 li 元素。

<link href="css/chosen.css" rel="stylesheet">
<script type="text/javascript" src="js/chosen.jquery.js"></script>
<div class="popover-content">
<p>                            
<select class="chosen-select text-left" style="width:100%;"  onchange="setCountry();" id="conid">
<option value="" selected>Select Country</option>
<?php
foreach ($country as $v) {
?>
<option value="<?php echo $v['country_id']; ?>"><?php echo $v['country_name']; ?></option>
    <?php
 }
?>
</select>
</p>
</div>
<div id="popupcity" class="popover" style="width:270px">
<div class="arrow"></div>
<h3 class="popover-title">Select City</h3>
<div class="popover-content" id="ctchoosen">
<p>                            
<select class="text-left" style="width:100%;" id="ctid" onchange="setCity();">
<option value="" selected>Select City</option>
</select>
</p>
</div>
</div>

当用户select选择国家时,城市值将添加到城市select列表中。

function setCountry(){
        var conval=document.getElementById('conid');
        var selectVal='';
        if (conval.selectedIndex == -1){
            return null;
        }else{
            selectVal=conval.options[conval.selectedIndex].text;
            $("#popupcountry").removeClass("in");
        }
        document.getElementById('bindCon').innerHTML=selectVal;
        $('#borderCon').css('border', '');
        //console.log('contr',conval.options[conval.selectedIndex].value);
        var url="common.php?action=getCity";
        $.post(url,{"con_data":conval.options[conval.selectedIndex].value},function(data){
            var obj=JSON.parse(data);
            console.log('data1',obj);
            var ctData='';
            $('#ctid').find('option').not(':first').remove();
            $('#ctid').removeClass('chosen-select');
            $('.chosen-select').chosen();
            if(obj.isData==1){
                ctData=obj.cid;
                $.each(ctData, function(idx, o) {

                    $("#ctid").append("<option value="+o.city_id+">"+o.city_name+"</option>");
                    //$("#ctchoosen > ul").append('<li class="active-result" data-option-array-index='+this.city_id+'>'+this.city_name+'</li>');
                })
                $('#ctid').addClass('chosen-select');
                $('.chosen-select').chosen();
            }
        })
      }

当用户 select 在国家 select 列表中选择任何选项时,城市正在追加,我需要 select box/auto 创建的列表项中的城市要更新的元素。

我可以重置 select 框,但无法重置自动创建的列表项元素,当用户 select 访问城市所属的任何新国家/地区时,这些元素不会向用户显示.我还使用 PHP 进行数据库操作。

Chosen 提供了一个可以触发的事件。来自 the documentation:

  • Updating Chosen Dynamically

    If you need to update the options in your select field and want Chosen to pick up the changes, you'll need to trigger the "chosen:updated" event on the field. Chosen will re-build itself based on the updated content.

    $("#form_field").trigger("chosen:updated");
    

    1

当城市列表有选项时,而不是只调用

$('.chosen-select').chosen();

添加城市后,触发更新事件:

$('#ctid').trigger("chosen:updated");

请参阅下面的演示。

//track whether options have been added to the list 
var cityOptionsAdded = false;

function setCountry() {
  var conval = document.getElementById('conid');
  var selectVal = '';
  if (conval.selectedIndex == -1) {
    return null;
  } else {
    selectVal = conval.options[conval.selectedIndex].text;
    $("#popupcountry").removeClass("in");
  }
  $('#borderCon').css('border', '');
  var url = conval.options[conval.selectedIndex].value + ".json";
  $.post(url, function(obj) {
    var ctData = '';
    $('#ctid').find('option').not(':first').remove();
    $('#ctid').removeClass('chosen-select');
    chosenSelect = $('.chosen-select').chosen();
    if (obj.isData == 1) {
      ctData = obj.cid;
      $.each(ctData, function(idx, o) {

        $("#ctid").append("<option value=" + o.city_id + ">" + o.city_name + "</option>");
      });
      if (cityOptionsAdded) { //subsequent addition of cities to list
        $('#ctid').trigger("chosen:updated");
      } else { //first time adding cities to list
        cityOptionsAdded = true;
        $('#ctid').addClass('chosen-select');
        chosenSelect = $('.chosen-select').chosen();
      }
    }
  });
}
/**override jQuery ajax for this sandbox
  because real AJAX requests are disabled 
  in this environment
*/
$.post = function(url, callback) {
  var data;
  if ($('#conid').val() == 'CA') {
    data = {
      "isData": true,
      "cid": [{
        "city_id": "OT",
        "city_name": "Ottowa"
      }, {
        "city_id": "VA",
        "city_name": "Vancouver"
      }]
    };
  }
  if ($('#conid').val() == 'SE') {
    data = {
      "isData": true,
      "cid": [{
        "city_id": "ST",
        "city_name": "Stockholm"
      }, {
        "city_id": "LU",
        "city_name": "Lund"
      }]
    };
  }
  callback(data);
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/chosen/1.7.0/chosen.jquery.min.js"></script>
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/chosen/1.7.0/chosen.min.css" />
<div class="popover-content">
  <p>
    <select class="chosen-select text-left" style="width:100%;" onchange="setCountry()" id="conid">
        <option value="" selected>Select Country</option>
        <option value="CA">Canada</option>
        <option value="SE">Sweden</option>
      </select>
  </p>
</div>
<div id="popupcity" class="popover" style="width:270px">
  <div class="arrow"></div>
  <h3 class="popover-title">Select City</h3>
  <div class="popover-content" id="ctchoosen">
    <p>
      <select class="text-left" style="width:100%;" id="ctid">
          <option value="" selected>Select City</option>
        </select>
    </p>
  </div>
</div>


1https://harvesthq.github.io/chosen/#change-update-events