使用CSS选中/取消选中复选框时切换文本和文本框

时间:2013-12-03 04:07:57

标签: javascript jquery html css checkbox

在我的HTML程序中,我正在尝试实现一个功能,其中有一个文本问题,“你今天工作了吗?”然后是一个复选框。如果选中复选框是,我想要出现一个新行,询问“你工作了多长时间?”然后是文本框。 我目前有CSS实现了我的目标,但它只切换文本框,你有多长时间不断显示。如何将文本与文本框一起隐藏?这是我的CSS代码:

function $_(IDS) { return document.getElementById(IDS); }
function toggle(Info) {
var CState = $_(Info);
if (CState.style.display != "none") { CState.style.display = "none"; }
                               else { CState.style.display = "inline"; }
}
function HideElem(IDS1, IDS2) {
  toggle(IDS1);
  toggle(IDS2);
}

function inputFocus(i){
    if(i.value==i.defaultValue){ i.value=""; i.style.color="#000"; }
}
function inputBlur(i){
    if(i.value==""){ i.value=i.defaultValue; i.style.color="#888"; }
}

这是用HTML实现的:

Did you work out today? <div class="checkboxFour">
  <input type="checkbox" value="1" onchange = "HideElem('share','meal')" id="checkboxInput" name="" />
  <label for="checkboxInput"></label>
  </div>
  <span id= "share">
    </span> <br><br>How long did you work out? <input type="text" id="meal" name="meal" size="40" style="display:none;" 
    value="Example: 8.5 Hours" onfocus="inputFocus(this)" onblur="inputBlur(this)">

我也在使用程式化的复选框,如果这会改变一些事情。谢谢你的帮助。

2 个答案:

答案 0 :(得分:0)

您不能将css样式添加到文本节点(标题),因此将标题和输入元素包装在另一个元素中并将可见性应用于该包装元素

<input type="checkbox" value="1" onchange="HideElem('share','mean-ct')" id="checkboxInput" name="" />

然后

<span id="mean-ct" style="display:none;">
    How long did you work out?
<input type="text" id="meal" name="meal" size="40" value="Example: 8.5 Hours" onfocus="inputFocus(this)" onblur="inputBlur(this)" />
</span>

演示:Fiddle

答案 1 :(得分:0)

使用span标记包裹您的问题并为其指定id。请尝试:

HTML:

<span id="how" style="display:none;">How long did you work out? </span>

的javascript:

if (CState.style.display != "none") { 
  CState.style.display = "none"; 
  document.getElementById("how").style.display = "none"; //hide the question
}
else { 
    CState.style.display = "inline"; 
    document.getElementById("how").style.display = "inline"; //display the question
}

Demo