Jquery 对select 事件的操作

功能需求:在selectoption为“默认”时,本tr内的inputdisplay为block在selectoption不为“默认”时,本tr内的inputdispla... 功能需求:
在select option为 “默认”时,本tr内的 input display为block
在select option不为“默认”时,本tr内的 input display为none

<tr>
<td>
<select name="category[]">
<option value="0">默认</option>
<option value="1">自定义</option>
</select>
</td>
<td>
<input style="display:block" type="text" class="txt" size="8" name="sitename[]">
</td>
</tr>
<tr>
<td>
<select name="category[]">
<option value="0">默认</option>
<option value="1">自定义</option>
</select>
</td>
<td>
<input style="display:block" type="text" class="txt" size="8" name="sitename[]">
</td>
</tr>
展开
 我来答
pppxiong
推荐于2017-09-26 · TA获得超过307个赞
知道小有建树答主
回答量:107
采纳率:100%
帮助的人:130万
展开全部
function changetxt(ele){
if($(ele).val()=='0'){
$('mytxt').css('display','block');
}
else{
$('mytxt').css('display','none');
}
}

<tr>
<td>
<select name="category[]" onchange="changetxt(this)">
<option value="0">默认</option>
<option value="1">自定义</option>
</select>
</td>
<td>
<input id="mytxt" style="display:block" type="text" class="txt" size="8" name="sitename[]">
</td>
</tr>
追问
嗯,这个是针对单行的,的确可以这样处理。
但实际上,我的页面里有很多行。
这样吧,我给出我的设计思路,你帮我把代码写出来,我把分给你:
$("select").change(function()
{
if($(this).val()=='0')
{
本select所在的行内,所有input设置为display:none
}
else
{
本select所在的行内,所有input设置为display:block
}
});
追答
用到好多个parent,children,last
$("select").change(function(){
if($(this).val()=='0')
$(this).parent().parent().children().last().children().css('display','block');
else
$(this).parent().parent().children().last().children().css('display','none');
});
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式