【问题标题】:Relative form action resolves to absolute URL?相对表单操作解析为绝对 URL?
【发布时间】:2012-09-25 14:31:06
【问题描述】:

我正在尝试获取放置在表单操作中的实际字符串。问题是当我这样做时,即使相对路径在 HTML 中,action 属性也会解析为绝对路径。如何获取 action 属性中的实际字符串?

这是我所指的示例: http://jsfiddle.net/MSY4s/

【问题讨论】:

    标签: javascript jquery forms dom


    【解决方案1】:

    如果您已经在使用 jquery,我会使用 .attr 函数,而不是从 jQuery 对象中提取 DOM 元素。像这样:

    $("form").attr("action");
    

    这应该给你真正的动作属性。在您提供的示例中,它应该看起来像“/somewhere”。 jFiddle 中的第二个示例将显示完整路径,因为那是 action 属性中的内容。

    【讨论】:

    • 好点。有基本的javascript评估它的原因吗?
    • @ianpgall 这是个好问题,我也想知道。我的假设是,这只是该函数的编写方式,以便浏览器知道提交的完整 URL,但是如果有人知道更具体的内容,我非常想知道。
    • 该属性的值与它在原始 HTML 中出现的一样。评估财产的价值。如果您不知道属性和属性之间的区别,那么值得一读。
    • @ianpgall 不错的发现,很有趣。 Lonesomeday,非常好的信息,谢谢。
    【解决方案2】:

    相对 URL 总是根据当前文档的 URL 解析为绝对 URL。

    【讨论】:

    • 不是我,但我假设是因为答案没有直接回答 OP 的问题。他在问如何获取相对URL。您的回答会对该问题或现有答案做出很好的评论。
    • 这与它发生在 Javascript 中的原因无关,尤其是当它可以用jQuery.attrgetAttribute 清楚地检索时。
    • @Teeg :我同意,我可能应该详细说明而不是发表声明。 @ianpgall :我试图不考虑jQuery
    • @harsha 是的,但在我的另一个答案的评论中,您可以使用 getAttribute 并且不会评估为绝对 URL。正如 lonesomeday 指出的那样,这可能是属性和属性之间的区别。
    【解决方案3】:

    试试这个:

    提供两个表单 ID:

    <form id="form1" action="/somewhere" method="post">
    <input type="text" name="test" />
    </form>
    
    <form id="form2" action="https://fiddle.jshell.net/somewhere2" method="post">
    <input type="text" name="test" />
    </form>​
    

    然后使用这些id就可以得到每个表单的action属性:

    $('#form1').attr('action');
    
    $('#form2').attr('action');
    

    您也可以使用相同的标签设置动作属性:

    $('#form1').attr('action', '[New Action Value]');
    
    $('#form2').attr('action', '[New Action Value]');
    

    希望这会有所帮助。

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2010-10-03
      • 2019-03-14
      • 2014-12-12
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多