CSS与JS中的相对路径引用简单介绍
发布时间:2014-05-19 14:30:21 作者:佚名
我要评论
javascript和css文件中采用相对路径,其基准路径是完全不同的,下面为大家介绍下CSS与JS中的相对路径引用,不了解的朋友可以参考下
javascript和css文件中采用相对路径,其基准路径是完全不同的。
1.javascript引用资源(比如图片)相对路径是以宿主路径(被引用的网页比如你在首页index.php引用了某js文件,则index.php即为宿主)所处位置为基准。
2.css引用资源(比如图片)相对路径是以.css文件所处位置为基准!
大家在html中通常会导入一些外部的css、js文件,而其中一个比较容易被忽视的问题就是路径问题,有时候,我们在css、js中都有通过路径来引入一张图片的需求,当我们采用相对路径的时候,在css和js中引用图片的相对路径的基准是不一样的。在css中出现的相对路径,是以css文件所在路径为基准的,而js中的路径则是以导入此js的网页文件所在的位置为基准的。
举个例子来说明这个问题。
假如我们有如下文件目录树:(\是文件夹)
–\site
——\images
———index_02.jpg
——test.htm
–\css
——\css
———-test.css
–\js
——\js
———-test.js
引用代码如下:
test.css
#imgtest
{
background-image:url(../../site/images/index_02.jpg);
width:500px;
height:50px;
border:solid 1px red;
}
test.js
function writeimg()
{
document.write(“<img src=’images/index_02.jpg’ />”);
}
test.htm
<!DOCTYPE html PUBLIC “-//W3C//DTD XHTML 1.0 Transitional//EN” “http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd”>
<html xmlns=”http://www.w3.org/1999/xhtml” >
<head>
<title>test</title>
<script type=”text/javascript” src=”../js/js/test.js”></script>
<link href=”../css/css/test.css” rel=”stylesheet” type=”text/css” />
</head>
<body>
<script type=”text/javascript”>
writeimg();
</script>
<div id=”imgtest”></div>
</body>
</html>
从例子,我们注意到css引用的是css目录与index_02.jpg的关系,js引用的是test.htm目录与与index_02.jpg的关系。但一般时候我们的css和js文件多在不同的网页上引用,他们有不同的宿主环境,所以使用被调用的路径做基准路径是安全的,但使用调用者的路径作为基准路径会造成路径错误,无法加载。通常情况下,js不仅仅是一个html在于,特别对于动态网页而言,js中的路径引用应该采用绝对路径,可以通过定义一个全局变量如path来活动项目的真实路径(像jsp中就可以用request.getSession().getServletContext().getRealPath(“/”)),然后在每个路径上加上path(path+你的路径)从而取出路径错误的问题。
1.javascript引用资源(比如图片)相对路径是以宿主路径(被引用的网页比如你在首页index.php引用了某js文件,则index.php即为宿主)所处位置为基准。
2.css引用资源(比如图片)相对路径是以.css文件所处位置为基准!
大家在html中通常会导入一些外部的css、js文件,而其中一个比较容易被忽视的问题就是路径问题,有时候,我们在css、js中都有通过路径来引入一张图片的需求,当我们采用相对路径的时候,在css和js中引用图片的相对路径的基准是不一样的。在css中出现的相对路径,是以css文件所在路径为基准的,而js中的路径则是以导入此js的网页文件所在的位置为基准的。
举个例子来说明这个问题。
假如我们有如下文件目录树:(\是文件夹)
–\site
——\images
———index_02.jpg
——test.htm
–\css
——\css
———-test.css
–\js
——\js
———-test.js
引用代码如下:
test.css
复制代码
代码如下:#imgtest
{
background-image:url(../../site/images/index_02.jpg);
width:500px;
height:50px;
border:solid 1px red;
}
test.js
function writeimg()
{
document.write(“<img src=’images/index_02.jpg’ />”);
}
test.htm
复制代码
代码如下:<!DOCTYPE html PUBLIC “-//W3C//DTD XHTML 1.0 Transitional//EN” “http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd”>
<html xmlns=”http://www.w3.org/1999/xhtml” >
<head>
<title>test</title>
<script type=”text/javascript” src=”../js/js/test.js”></script>
<link href=”../css/css/test.css” rel=”stylesheet” type=”text/css” />
</head>
<body>
<script type=”text/javascript”>
writeimg();
</script>
<div id=”imgtest”></div>
</body>
</html>
从例子,我们注意到css引用的是css目录与index_02.jpg的关系,js引用的是test.htm目录与与index_02.jpg的关系。但一般时候我们的css和js文件多在不同的网页上引用,他们有不同的宿主环境,所以使用被调用的路径做基准路径是安全的,但使用调用者的路径作为基准路径会造成路径错误,无法加载。通常情况下,js不仅仅是一个html在于,特别对于动态网页而言,js中的路径引用应该采用绝对路径,可以通过定义一个全局变量如path来活动项目的真实路径(像jsp中就可以用request.getSession().getServletContext().getRealPath(“/”)),然后在每个路径上加上path(path+你的路径)从而取出路径错误的问题。
相关文章
- 这篇文章主要介绍了CSS编程的外部CSS文件引用方法,是CSS入门学习中的基础知识,需要的朋友可以参考下2015-08-26
- 目前有两种引用方式,一种是通过在head里面的link来引用,另外一种是直接通过import来引用,示例代码如下,需要的朋友不要错过2014-08-06
- CSS都是正确的,链接也没有出错的话,为什么偏偏CSS样式不生效2011-07-22
- js与css的引用方法,都是基础的东西。2011-06-23
- Photoshop制作CSS网页制作的背景图.2010-01-21
- 看到淘宝网页中这样写使用的是import,而很多网站都是使用link,当然还有一些页面比较简单,流量很大的网站,是直接将CSS写在html代码中的?他们有什么区别?2009-11-19
- 通常,我们的页面都是引用了很多样式文件,同时样式文件给我们的页面设置了很多背景图片。但是这里有个小细节容易忽视。图片的referer来源处理存在浏览器的差异。2009-07-29
- 网页制作Webjx文章简介:这两天刚写完XHTML加载CSS的几种方式,其中外部引用CSS分为两种方式link和@import。 有很多网页中的CSS链接与引用是这样写的:2009-04-02
- 这篇文章主要介绍了CSS的四种引用方式,需要的朋友可以参考下2018-09-07


最新评论