javascript - 如何使用 javascript 和 PHP 动态触发 onChange 事件

标签 javascript php jquery

我需要一个帮助。我正在从数据库中获取数据,我需要在获取数据时通过 onChange 事件调用一个 Javascript 函数。让我解释一下我的代码。

<?php
  $id=$_GET['ids'];
  if($id!=""){
    $getcustomerobj = $dbobj->getFeedbackData($db,$id);
   }
?>

  <div style="width:24%; float:left; padding:10px;">Answer Type : 
<select class="form-control" id="answer_type" name="answer_type" onChange="selectScale(this.value);">
<option value="">Select Answer Type</option>
 <?php
$ustatus=array("status"=>'1');
$feeddata=$db->kf_answertype->find($ustatus);
 foreach($feeddata as $v){
?>
<option value="<?php echo $v['_id']; ?>" <?php if($getcustomerobj->answer_type == $v['_id'] or $_REQUEST['answer_type'] == $v['_id']){ print 'selected'; } ?>><?php echo $v['answertype']; ?></option>                          
 <?php } ?>
</select>
</div>
 <div style="width:24%; float:left; padding:10px; display:none;" id="scaleid">Scale :
<select class="form-control" id="nscale" name="noofscale"> 
<option value="">Select No Of Scale</option>
<?php
$status=array("status"=>'1');
 $feeddata=$db->kf_scale->find($ustatus);
 foreach($feeddata as $v){
 ?>
<option value="<?php echo $v['_id']; ?>" <?php if($getcustomerobj->no_of_scale == $v['_id'] or $_REQUEST['no_of_scale'] == $v['_id']){ print 'selected'; } ?>><?php echo $v['noofscale']; ?></option>                           
     <?php } ?>
  </select>
 </div>

<script>
  function selectScale(id){
    console.log('select scale',id);
    var data=$.param({'op':'getscale','sid':id});
    $.ajax({
        method:'POST',
        url:"dbcon/DBConnection.php",
        data:data
    }).done(function(msg){
        //console.log('msg',msg);
        var dedata=JSON.parse(msg);
        //console.log('decode',dedata);
        if(dedata[0]['data']==1){
            document.getElementById("scaleid").style.display="block";
        }
        if(dedata[0]['data']==0){
            document.getElementById("scaleid").style.display="none";
        }
    });
}
</script>

在这里,当从数据库获取数据时,我需要将Answer Type下拉字段设置为某个值。第二个下拉列表(即Scale)是取决于第一个下拉列表,我需要调用使用 onChange 事件触发的 selectScale 函数。请帮助我。

最佳答案

我认为您可以在文档就绪时为第一个下拉菜单调用 onchange 事件,因此将选择第二个下拉菜单值。

  $(document).ready(function(){
    $("#answer_type").trigger("change");
    });

也许这对你有帮助。

关于javascript - 如何使用 javascript 和 PHP 动态触发 onChange 事件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37268419/

相关文章:

php - 成员变量和成员函数同名

PHP Cookie 不起作用

javascript - jQuery JTable 如何拖动行

javascript - jquery datepicker 不适用于克隆的元素

javascript - 为什么 JS 中的一些函数有 prototype.constructor prop 而另一些没有?这些功能有什么区别?

javascript - 请求 npm : Handling Redirects

javascript - JS中构造函数 "creates"无限循环

javascript - 如何按值过滤 `objects`

php - 如何在 jquery ui 自动完成中使用 json 传递隐藏的 id?

javascript - 如何从容器中删除选定的图像