javascript - 组合 JavaScript 函数

标签 javascript html forms function onclick

您好,我正在使用 javascript 函数在单击文本框时阻止文本框,最初文本框包含各自的标签名称,例如:客户名称、公司等。单击文本框时,它会使文本框为空,以便数据可以是类型。为此,我使用一个javascript函数,对于每个文本框,我必须有一个单独的函数,任何人都可以告诉我如何组合所有这些函数,每个函数中唯一不同的是文本框中使用的值和文本框名称.

Javascript 函数

    function clientnameclear() {
    if(document.bunkerfrm.clientname.value=="Client Name") {
        var bunkerfrm = document.bunkerfrm.clientname.value="";
        var bunkerfrm = document.bunkerfrm.clientname.focus();
    }
    else {
        var bunkerfrm = document.bunkerfrm.clientname.focus();
    }
}

function clientnamereset() {
    if(document.bunkerfrm.clientname.value=="") {
        var bunkerfrm = document.bunkerfrm.clientname.value="Client Name";
    }
}

function vesselnameclear() {
    if(document.bunkerfrm.vesselname.value=="Vessel Name") {
        var bunkerfrm = document.bunkerfrm.vesselname.value="";
        var bunkerfrm = document.bunkerfrm.vesselname.focus();
    }
    else {
        var bunkerfrm = document.bunkerfrm.vesselname.focus();
    }
}

function vesselnamereset() {
    if(document.bunkerfrm.vesselname.value=="") {
        var bunkerfrm = document.bunkerfrm.vesselname.value="Vessel Name";
    }
}

function compclear() {
    if(document.bunkerfrm.company.value=="Company") {
        var bunkerfrm = document.bunkerfrm.company.value="";
        var bunkerfrm = document.bunkerfrm.company.focus();
    }
    else {
        var bunkerfrm = document.bunkerfrm.company.focus();
    }
}

function compreset() {
    if(document.bunkerfrm.company.value=="") {
        var bunkerfrm = document.bunkerfrm.company.value="Company";
    }
}

HTML 代码是

<form name="bunkerfrm" id="bunkerfrm" action="#" method="post"><br>
<input type="text" name="clientname" class="txtbox" value="Client Name" onmousedown="clientnameclear()" onclick="clientnameclear()" onblur="clientnamereset()" />
<br /><br>
<input type="text" name="company" class="txtbox" value="Company" onmousedown="compclear()" onclick="compclear()" onblur="compreset()" />
<br /><br>
<input type="submit" name="submitting" class="bunksubmit" value="Send Your Inquiry" /><br>
 </form>

最佳答案

首先,将默认值存储在某处,例如给定输入的alt

<form name="bunkerfrm" id="bunkerfrm" action="#" method="post"><br>
<input type="text" name="clientname" alt="Client Name" class="txtbox" value="Client Name" onfocus="clear_text(this);" onblur="reset_text(this);" />
<br /><br>
<input type="text" name="company" class="txtbox" alt="Company" value="Company" onfocus="clear_text(this);" onblur="reset_text(this);" />
<br /><br>
<input type="submit" name="submitting" class="bunksubmit" value="Send Your Inquiry" /><br>
 </form>

然后将输入元素 this 作为参数传递给这些 onfocus/onblur 函数:

function clear_text(elem)
{
    if (elem.value == elem.alt)
        elem.value = "";
}

function reset_text(elem)
{
    if (elem.value == "")
        elem.value = elem.alt;
}

如果其值与存储在 alt 属性中的占位符相同,则在获得焦点时将清除输入。事件 onblur 将触发 reset_text 函数,该函数将检查该值是否为空并将其恢复为存储在 alt 属性中的默认占位符。

关于javascript - 组合 JavaScript 函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10441660/

相关文章:

javascript - 带有 ajax 请求的空响应正文

javascript - 我想要 dd.d.dd.ddddd 或 dd.d.d.ddddd 类型的数据的正则表达式

php - 关于重定向应该如何工作的问题

javascript - 在 Javascript 中使用多个提交按钮处理表单提交

javascript - 如果将命名函数声明放在 return 语句中,为什么它不会被提升?

javascript - 结合滚动提要推特风格

javascript - Tinymce 中的简码下拉框在 WordPress 3.9 中不起作用?

javascript - 处理多个 Canvas 上下文的解决方案

html - CSS 动画 : How can I put a text using pseudo-element for each image?

php - 无法连接数据库?