最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

javascript - Safest way to make sure a HTML button does not send any information to the server - Stack Overflow

programmeradmin0浏览0评论

I'm working on a javascript app that has a form with a button that processes inputs in the browser. It is important that the data never accidentally get sent to the server when the button is pushed. Situations where this might happen is the browser may not have javascript enabled or the DOM implementation may have a bug where the click binding on the button is lost briefly (I've seen this happen once in testing but not in a way that is reproducible).

The obvious way to do this seems to be to not have a button or a submit but some other structure which I would style to look like a button. Are there better ideas? Is there anything like a form attribute that disables data being sent from the form -- and is well implemented across browsers?

Thanks

I'm working on a javascript app that has a form with a button that processes inputs in the browser. It is important that the data never accidentally get sent to the server when the button is pushed. Situations where this might happen is the browser may not have javascript enabled or the DOM implementation may have a bug where the click binding on the button is lost briefly (I've seen this happen once in testing but not in a way that is reproducible).

The obvious way to do this seems to be to not have a button or a submit but some other structure which I would style to look like a button. Are there better ideas? Is there anything like a form attribute that disables data being sent from the form -- and is well implemented across browsers?

Thanks

Share Improve this question edited Jun 24, 2009 at 22:38 Sinan Ünür 118k15 gold badges200 silver badges343 bronze badges asked Feb 13, 2009 at 23:31 Steven NobleSteven Noble 10.4k13 gold badges48 silver badges57 bronze badges
Add a ment  | 

5 Answers 5

Reset to default 10
<input type="button">

does not submit a form, unlike

<input type="submit"> 

Try using an <input type="button"> that's not in the form. That way, even if the button is clicked, and even if the browser does somehow erroneously think that it should be submitting something, it will have no idea where to send the data for processing because there's no action attribute associated to the button.

Alternatively, you could look at this question regarding imageless CSS buttons used in Gmail.

Surely some kind of image button would do? Style up a nice looking image, and use an onclick event to post back? Would certainly solve the JavaScript disabled problem.

Try creating just a button:

<input type="button" value="some text">

You can use onclick= handler to process the data.

If you want to do fancier non-input buttons, check out what gmail does: http://stopdesign./archive/2009/02/04/recreating-the-button.html

You're allowed to have buttons and inputs outside of a <form>, and in that case there's no possible way anything can be submitted to the server.

发布评论

评论列表(0)

  1. 暂无评论