21

单击 svg 图像时,有什么方法可以发出 POST 请求吗?

到目前为止,我最好的尝试如下:

<form action="/test-button" method="POST">
   <input name="Submit" type="submit" value="Submit" /> 
   <svg  >
     <rect width="100" height="100" >
   </svg> 
</form>

这是一个黑色矩形,旁边有一个提交按钮。

我想让人们在几张图片之间进行选择,所以这可能是一个不错的解决方案,但是有没有办法制作一张图片,当点击它时会触发一个 POST?

不使用javascript的额外积分。

4

6 回答 6

25

警告:这有点骇人听闻,但据我所知,它是 100% 合法的,并且不需要 javascript。

由于label元素也可以用来控制它的关联输入,你可以尝试这样的事情:

<form action="/test-button" method="POST">
  <label>
   <input type="submit" name="image" value="one">
   <svg><rect width="100" height="100"></rect></svg> 
  </label>
  <label>
   <input type="submit" name="image" value="two">
   <svg><rect width="100" height="100"></rect></svg> 
  </label>
</form>
 ​

然后用 CSS 隐藏提交按钮。您可以在标签中添加任何您想要的内容。

当您单击标签中的任何内容时,它将触发其中的提交按钮并提交表单,该按钮value位于 POST 数组中。

还有一个<input type="image">, 但这是出于完全不同的目的(跟踪单击位置的坐标)。

于 2012-11-30T17:29:14.737 回答
11

这似乎是该<button>元素的一个很好的用例。

<form action="/test-button" method="POST">
   <button>
      <svg>
         <rect width="100" height="100" >
      </svg>
   </button>
</form>

单击按钮元素执行与 完全相同的工作input[type="submit"],因此您可以完全替换输入。如果你走这条路,你也可以考虑在按钮内放置一个文本标签和/或title在 svg 内放置一个用于可访问性目的的文本标签。

于 2016-07-11T16:19:26.973 回答
4

没有 JS 是完全不可能的,但是你可以用 JS 来做。附上一个onclick(),只需使用:document.getElementById('formID').submit();

HTML:

<form action="/test-button" method="POST" id="submittingForm">
   <input name="Submit" type="submit" value="Submit" /> 
   <svg onclick="submitForm();">
     <rect width="100" height="100" >
   </svg> 
</form>

和 JS(在您的<head></head>标签内):

<script type="text/javascript">
    function submitForm()
    {
        document.getElementById("submittingForm").submit();
    }
</script>
于 2012-11-30T17:17:57.240 回答
4

这,也许:

<form action="/test-button" method="POST">
    <input type="image" src="data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciPjxyZWN0IHdpZHRoPSIxMDAiIGhlaWdodD0iMTAwIi8+PC9zdmc+">
</form>

jsfiddle:http: //jsfiddle.net/Xawuv/

于 2012-11-30T17:36:47.207 回答
2

这是一个简单的按钮,盒子里有一个闪电。

 <svg x="167" y="8" cursor="pointer" width="30" height="30"   visibility="visible" >
                <g id="Flash">
                    <g fill="#FFCC00"  stroke="#D57300" stroke-width="2" >
                        <path stroke-linecap="round" d="m 10.311873 9.0776039 9.400261 -7.988867 -0.05562 6.2501137 -2.224914 0.093987 -0.05562 5.5452134 11.402682 -0.04699 -18.522406 16.024725 0.05562 -6.015145 2.169291 -0.09398 -0.05562 -5.874165 -11.51392928 0.04699 z"/>
                    </g>
                </g>    
                <rect width="30" height="30"  opacity="0"  fill="transparent"    fill="url(#Flash)" id="Flash_Button"  onclick="Flash(evt);" />     
    </svg>

这是您单击时的功能脚本

function Flash(){
// post whatever you want inside here

}

当您创建一个按钮并在其中有线条时的问题,当您将 onclick 放入父元素时,您不会单击所有 svg 元素,而是单独单击并单击所有子元素。因此,您需要在 svg 内创建一个具有父元素宽度和高度的矩形并将其隐藏,然后将其放在那里 onclick!

于 2013-07-12T21:40:20.183 回答
0

有些答案忘记隐藏输入。这应该完美地工作:

复制粘贴就行了。

<label class="cursor: pointer;">
    <input type="submit" name="mysubmit" value="val1" style="display: none;">
    <svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" 
fill="currentColor" class="bi bi-arrow-down-up" viewBox="0 0 16 16">
        <path fill-rule="evenodd" d="M11.5 15a.5.5 0 0 0 
         .5-.5V2.707l3.146 3.147a.5.5 0 0 0 .708-.708l-4-4a.5.5 0 0 0-.708 0l-4 
         4a.5.5 0 1 0 .708.708L11 2.707V14.5a.5.5 0 0 0 .5.5zm-7-14a.5.5 0 0 1 
         .5.5v11.793l3.146-3.147a.5.5 0 0 1 .708.708l-4 4a.5.5 0 0 1-.708 0l-4- 
         4a.5.5 0 0 1 .708-.708L4 1 
         3.293V1.5a.5.5 0 0 1 .5-.5z"/>
    </svg>
</label>


            
于 2022-01-05T03:37:02.227 回答