Rfc2616 lists many methods besides GET and POST, like, say, DELETE, PUT etc. Method field in html forms, though, seems to be allowed to specify only GET or POST.
Is it possible to create a link or form in a html page that uses a request method that is not GET or POST?
Was trying to figure this out for a rails app that was using Angular on the front end; these seems to work for that environment:
Edit: Just to give everyone a heads up, I think you still need to have jQuery for this to work. I removed jQuery and it stopped working; I put it back and it started working.
You certainly can’t create a link that uses anything other than
GET
. Since HTML began, links have been meant to be idempotent and free from side effects.For forms and
XMLHTTPRequests
, Caps’ link is the place to look: Are the PUT, DELETE, HEAD, etc methods available in most web browsers?.@Ifnot plugin is great but I created a one based on
$.ajax
function instead of appendinghidden
forms! here's a simple example for aDELETE
requestHTML
JavaScript
It is not possible to create a link or form with delete method.
Many web framework create a hidden input called "_method" for handling PUT and DELETE.
I created a plugin for automatically convert links to forms : RestfulizerJs
You can take a look here : https://github.com/Ifnot/RestfulizerJs
By default, not there is no way to do this. Links always perform GETs, forms can use GETs or POSTs.
That said, with a little JavaScript, it's possible. Rails for instance ships with helpers which will add a
data-method
attribute to links. Rails-UJS is a jQuery library that will transparently intercept clicks on these links, and trigger a form submit with a_method
parameter used for overriding the normal HTTP method. Finally Rack will intercept requests with a_method
params, and overwrite the request method with the value in_method
.Other frameworks no doubt follow a similar pattern.
If you want even more details, I've written up an explanation of how Rails, Rails-UJS, and Rack all work together to provide this.
It's good to know how your libraries work.
just add a data-method attribute,
<a data-method='put' href='whatever'>link</a>