2012-12-15 106 views
0

我使用此Java腳本函數來顯示錶單驗證提示。此功能正常與輸入元素..我的問題是我需要修改此功能與其他表單元素,如textarea,選擇框,複選框......任何人都可以告訴我我怎麼能做到這一點?使用表單元素顯示錶單驗證提示

這是我一直在使用功能..

function prepareInputsForHints() { 
    var inputs = document.getElementsByTagName("input"); 
    for (var i=0; i<inputs.length; i++){ 
     // test to see if the hint span exists first 
     if (inputs[i].parentNode.getElementsByTagName("span")[0]) { 
      // the span exists! on focus, show the hint 
      inputs[i].onfocus = function() { 
       this.parentNode.getElementsByTagName("span")[0].style.display = "inline"; 
      } 
      // when the cursor moves away from the field, hide the hint 
      inputs[i].onblur = function() { 
       this.parentNode.getElementsByTagName("span")[0].style.display = "none"; 
      } 
     } 
    } 
    // repeat the same tests as above for selects 
    var selects = document.getElementsByTagName("select"); 
    for (var k=0; k<selects.length; k++){ 
     if (selects[k].parentNode.getElementsByTagName("span")[0]) { 
      selects[k].onfocus = function() { 
       this.parentNode.getElementsByTagName("span")[0].style.display = "inline"; 
      } 
      selects[k].onblur = function() { 
       this.parentNode.getElementsByTagName("span")[0].style.display = "none"; 
      } 
     } 
    } 
} 

就是HTML

<div> 
    <label for="mobile">Mobile<img alt="required" src="images/required_star.png"> :</label> 
    <input id="mobile" class="text" type="text" maxlength="10" name="mobile" title="Eg: 0714556260"/> 
    <span class="hint">Use a 10 digits length number<span class="hint-pointer">&nbsp;</span></span> 
</div> 

我想這樣的事情與textarea的,但它是不工作...

<div> 
    <label for="qualification">Qualification Details<img alt="required" src="images/required_star.png">:</label> 
    <textarea id="qualification" class="textarea" rows="4" cols="30" name="qualification"></textarea> 
     <span class="hint">Describe about you<span class="hint-pointer">&nbsp;</span></span> 

</div> 
+0

你允許用戶jQuery ...?它會使代碼更加清潔。 – DashK

+0

你可以用jquery修改這個函數嗎?我對Jquery很新奇......所以不知道如何做到這個jQuery ... –

回答

1
$(document).ready(function() { 
$(".hint").css({ "display":"none" }); 
$("input.hint_needed, select.hint_needed, textarea.hint_needed, radio.hint_needed").on("mouseenter", function() { 
$(".hint").css({ "display":"inline" }); 
}).on("mouseleave", function() { 
$(".hint").css({ "display":"none" }); 
}); 
});​ 

<textarea id="qualification" class="hint_needed" rows="4" cols="30" name="qualification"></textarea> 

你可以使用這個!

http://jsfiddle.net/QD3Hn/1/

+0

它的jQuery! :);) –

+0

當我將此代碼添加到我的網頁..並單擊每個提示消息顯示在頁面上的表單元素。即使不向元素插入提示類。爲什麼它.. –

+0

你想要那些只有那些顯示暗示的元素嗎? –

1

更新:每個操作的要求,允許在懸停顯示提示也是如此。

這裏是我所基於非jQuery的執行代碼: (的jsfiddle:http://jsfiddle.net/E9njP/

<div> 
    <label for="mobile">Mobile* :</label> 
    <input id="mobile" class="text" type="text" maxlength="10" name="mobile" /> 
    <span class="hint">Use a 10 digits length number</span> 
</div> 
<div> 
    <label for="qualification">Qualification Details*:</label> 
    <textarea id="qualification" class="textarea" rows="4" cols="30" name="qualification"></textarea> 
    <span class="hint">Describe about you</span> 
</div> 
<div> 
    <label for="dropdown">Dropdown*:</label> 
    <select id="dropdown"><option>A</option><option>B</option></select> 
    <span class="hint">Hints for Select</span> 
</div> 

<!-- This is just for demo purpose --> 
<div> 
    <label>Tricky Input:</label> 
    <input/> 
    <span>Don't hide me! I am not a hint!</span> 
</div> 

...取而代之的元素做CSS的,我使用CSS來代替。下面是類...

div span.hint { 
    display: none; 
} 

div span.over, 
div span.focus { 
    display: inline; 
} 

...這是JavaScript的...

(function() { 
    // Since it's likely that you'll only ever run this function once 
    // (Once you attached the events, you'll probably never reuse this 
    // function again), I put it inside an IIFE to keep it "clean". 

    /** 
    * Toggle class on element without jQuery... 
    * 
    * @param {DOMElement} el Element to apply CSS to 
    * @param {string} css CSS class name to be applied 
    * @param {boolean} on Determine whether class name should be on the element or not 
    **/ 
    function getHandler(el, css, on) { 
     return function() { 
      // If we want to add CSS to the element, and it doesn't exist on the 
      // element yet, add it. 
      if (on && el.className.indexOf(css) === -1) { 
       el.className += ' ' + css; 
      } 
      // If we want to remove CSS from the element, and it exists, remove 
      // it. 
      else if (!on && el.className.indexOf(css) >= 0) { 
       el.className = el.className.replace(css, ''); 
      } 

      // NOTE This solution will lead to extra spacing in CSS name... 
     }; 
    } 

    function setHandler(inputEl, hintEl) { 
     // the span exists! on focus, show the hint 
     inputEl.onfocus = getHandler(hintEl, "focus", true); 
     inputEl.onmouseover = getHandler(hintEl, "over", true); 

     // when the cursor moves away from the field, hide the hint 
     inputEl.onblur = getHandler(hintEl, "focus", false); 
     inputEl.onmouseout = getHandler(hintEl, "over", false); 
    } 

    function prepareHintsByTag(tag) { 
     var inputs = document.getElementsByTagName(tag); 
     for (var i=0; i<inputs.length; i++){ 
      // test to see if the hint span exists first 
      if (inputs[i].parentNode.getElementsByTagName("span")[0]) { 
       var hintEl = inputs[i].parentNode.getElementsByTagName("span")[0]; 

       // Show "hint" only if it has the class of "hint" 
       if (hintEl.className.indexOf("hint") === 0) { 
        setHandler(inputs[i], hintEl); 
       } 
      } 
     } 
    } 

    // Scan the code  
    prepareHintsByTag("input"); 
    prepareHintsByTag("textarea"); 
    prepareHintsByTag("select"); 
})(); 
    ​ 

添加幾件事情的代碼...

  • 默認情況下,這些提示可能應該隱藏起來。我在CSS中做了一個默認。
  • 在切換CSS之前,檢查「span」類是否爲「提示」。 (只是所以你不會隱藏那些沒用的東西!)
  • 我重構了prepareHint函數,所以它可以重用SELECT,INPUT和TEXTAREA。
  • 我把處理準備提示的函數放在一個IIFE中,因爲它很可能只會做這個。你可以在這裏閱讀更多關於IIFE的信息:http://benalman.com/news/2010/11/immediately-invoked-function-expression/
  • 不是直接對元素的樣式進行樣式操作,而是將其移動到CSS類中。它應該更有意義...

這又是非jQuery版本 - 有更多的空間用於改進,但希望這可以滿足您的任務。

+0

你可以告訴我,當有人將鼠標移動到表單元素上時,顯示提示如何。不是單擊..現在我們需要單擊表單元素來查看提示。 。 –

+1

@SriyaniRathnayaka試試這個:http://jsfiddle.net/E9njP/ – DashK

+0

感謝您的幫助...工作.. –