Web 制作:外部 JS 文件中的绝对 URL?

Posted

技术标签:

【中文标题】Web 制作:外部 JS 文件中的绝对 URL?【英文标题】:Web production: Absolute URLs in external JS files? 【发布时间】:2009-02-18 09:13:20 【问题描述】:

我想知道,您是否知道在外部 javascript 文件中指定绝对 URL 的任何最佳做法?我正在寻找可维护的解决方案。

基本场景是当我需要在运行时通过 javascript 包含 css 文件,或对某些 URL 进行 ajax 调用,以及通常需要在(外部)javascript 文件中指定 URL 的其他情况。

如果你要更改服务器,或者可能引入 mod_rewrite,如何防止手动编辑 js 文件中的所有 url?

【问题讨论】:

【参考方案1】:

您可以使用以下属性构建一个 URL 字符串:

var thisurl = document.location.href;

这会给你当前页面的 URL 字符串,希望你能从那里解析它?

或者,如果您使用的是服务器端语言(例如 php),那么您可以使用它来获取 URL 字符串,这样会更快(this 是从这里复制粘贴的;未经我测试):

<?php
function curPageURL() 
 $pageURL = 'http';
 if ($_SERVER["HTTPS"] == "on") $pageURL .= "s";
 $pageURL .= "://";
 if ($_SERVER["SERVER_PORT"] != "80") 
  $pageURL .= $_SERVER["SERVER_NAME"].":".$_SERVER["SERVER_PORT"].$_SERVER["REQUEST_URI"];
  else 
  $pageURL .= $_SERVER["SERVER_NAME"].$_SERVER["REQUEST_URI"];
 
 return $pageURL;

?>
var thisurl = <?php echo curPageURL(); ?>;

或者您可以将属性存储在服务器上的文件中,该文件可以由服务器端语言解析。

【讨论】:

我几乎在 .NET 中做同样的事情。如果 OP 告诉我们服务器端平台会有所帮助。【参考方案2】:

您可以引入 javasript 类,该类保留所有 URL。像这样的

function urlContainer()
    this.searchServer = 'http://search.example.com';
    this.submitServer = 'http://submit.example.com';

然后在你的其他脚本文件中引用这个类,并使用如下 URL:

alert (new urlContainer().searchServer);

因此,您的所有外部 URL 都将包含在一个文件中。您可以获得更多创意并使用 baseUrls 和连接,但这取决于您。

【讨论】:

很好的解决方案,假设所有可能的服务器 URL 都是事先知道的。 如果需要,可以动态生成这个文件。 确实,这类似于我的第三个选项,但你需要知道/解析 Javascript 才能更新它:)【参考方案3】:

另一种(可能更简单)的解决方案可能是将您想要的 URL 存储到隐藏字段值中,然后使用客户端 Javascript 访问它。请注意,您的 Hidden 字段需要是 htmlInputHidden 或 HiddenField 控件。 (基本上,它需要有runat="server" 属性,以便它的值可以在服务器端设置。)

【讨论】:

以上是关于Web 制作:外部 JS 文件中的绝对 URL?的主要内容,如果未能解决你的问题,请参考以下文章

通过外部文件中的webpack.DefinePlugin设置变量 - 异步读取问题

java中如何判断web工程中图片的绝对路径是不是存在

Web.siteMap中的绝对URL

如何从Node.js中的URL加载外部js脚本

java(web)相对路径,绝对路径

相对路径和绝对路径的区别是啥?