在一个页面上画一个按钮,有四种办法:
- <input type="button" /> 这就是一个按钮。如果你不写javascript 的话,按下去什么也不会发生。
- <input type="submit" /> 这样的按钮用户点击之后会自动提交 form,除非你写了javascript 阻止它。
- <button> 这个按钮放在 form 中也会点击自动提交,比前两个的优点是按钮的内容不光可以有文字,还可以有图片等多媒体内容。(当然,前两个用图片背景也可以做到)。它的缺点是不同的浏览器得到的 value 值不同;可能还有其他的浏览器兼容问题。
- 其他标签,例如 a, img, span, div,然后用图片把它伪装成一个按钮。
从画面表现上看,通过CSS可以把两者描绘得完全一样。
----------------
在ie下,<button>标记恐怕还存在几个不大不小的问题。
- 在一个表单里,如果有一个以上”submit”类型的<button>标签存在,在表单被提交时,不管你点击哪个<button>,所有<button>的值都会被post/get。
- <button>的缺省type属性被设置为”button”,但是在A级别浏览器下,应该设置为”submit”才对
- 如果你用javascript去访问<button>的value属性,IE却返回了<button>的innerHTML属性,很让人恼火。 (可以使用”getAttributeNode”方法来避免.)
<form>
<button type="submit" value="1" name="action-1">text 1</button>
<button type="submit" value="2" name="action-2">text 2</button>
</form>
在IE下,上面两个button的数据都会被提交。并且ie会提交这两个button的innerText而不是value。而其它浏览器仅仅提交你点击的那个button。