我有一个表单根据用户的帐户设置(存储在MySQL数据库中并使用PHP提取)设置默认值。显示表单时,它会提取相关的帐户信息并填写表单(名字,姓氏,电子邮件,帐户类型等)
当用户的帐户类型为“admin”时,我希望表单的其余部分被禁用,并选择某些选项。如果用户的帐户类型是“admin”,因此默认选中“edit_type_admin”单选按钮(见下文),我想在页面加载时调用下面的makeEditDisable()函数(不需要任何点击)。
现在,表单会显示帐户类型,如下所示:
Client or Admin: <br />
Client <input type="radio" name="edit_type" id="edit_type_client" value="client" <? if($selected_type == 'client') { echo 'checked'; } ?> onclick="makeEditEnable()" />
Admin <input type="radio" name="edit_type" id="edit_type_admin" value="admin" <? if($selected_type == 'admin') { echo 'checked'; } ?> onclick="makeEditDisable()" />
当在两个选项之间切换时,onclick makeEditEnable()/ makeEditDisable()函数正常工作:
<script type="text/javascript">
function makeEditDisable(){
var x=document.getElementById("edit_access_begin")
x.disabled=true;
var x=document.getElementById("edit_access_expire")
x.disabled=true;
var x=document.getElementById("edit_project_access_yes")
x.checked=true;
var x=document.getElementById("edit_project_access_yes")
x.disabled=true;
var x=document.getElementById("edit_project_access_no")
x.disabled=true
}
function makeEditEnable(){
var x=document.getElementById("edit_access_begin")
x.disabled=false;
var x=document.getElementById("edit_access_expire")
x.disabled=false;
var x=document.getElementById("edit_project_access_yes")
x.disabled=false;
var x=document.getElementById("edit_project_access_no")
x.disabled=false
}</script>
答案 0 :(得分:1)
将此添加到加载元素后加载的脚本或函数,当然还有makeEditDisable()
加载后:
<? if($selected_type == 'admin') { echo 'makeEditDisable();'; } ?>
这应该调用你的功能。
答案 1 :(得分:1)
您可以使用PHP添加函数调用,例如@Jeffman answer。
但请确保在脚本本身之后添加 之后,或者在客户端上生成undefined function
错误。
或者您可以在页面onload或onDOMReady事件上调用它。
我还想建议清理脚本http://jsfiddle.net/DHxvk/
var editableFields = ['edit_access_begin','edit_access_expire','edit_project_access_yes','edit_project_access_no'];
function makeEditDisable(){
for(var i=0; i<editableFields.length; i++)
document.getElementById(editableFields[i]).disabled=true;
}
function makeEditEnable(){
for(var i=0; i<editableFields.length; i++)
document.getElementById(editableFields[i]).disabled=false;
}