gpt4 book ai didi

javascript - 组合 JavaScript 函数

转载 作者:行者123 更新时间:2023-11-28 21:03:31 26 4
gpt4 key购买 nike

您好,我正在使用 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/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com