HTML页面在不使用实时服务器时不显示某些元素。

huangapple go评论65阅读模式
英文:

HTML site not showing certain elements when not using live server

问题

当我在VS Code中使用实时服务器时,一切都按预期运行,但当我通过文件打开网站时,它不显示某些元素。我注意到这些元素通常需要链接到其他文件,例如@font-face和background-image: url()。

我尝试重新启动电脑,以为它只是没有加载或出现了问题,但事实并非如此。文件和路径的结构是正确的,因为在实时服务器模式下它能正常工作,所以我怀疑这不是问题。

以下是可能有问题的代码部分和文件与实时服务器的屏幕截图:

@font-face {
font-family: Raleway;
src: url(/fonts/Raleway-Medium.ttf);
}
main{
background-image: url('/img/pozadina.png');
background-repeat: no-repeat;
background-position: center;
}

实时服务器
HTML文件

英文:

When i use the live server in VS Code everything works as expected, however when I open the site via files it doesn't show certain elements. I've noticed that it's the ones that require linking to other files. For example @font-face and background-image: url()

I've tried restarting my PC thinking that it just didn't load or something but that wasn't the case. The files and paths are structured correctly since it works in live server mode so I doubt that that's the problem

Heres parts of code that are most likely problematic and screenshots of file vs. live server

@font-face {
    font-family: Raleway;
    src: url(/fonts/Raleway-Medium.ttf);
  }
main{
    background-image: url('/img/pozadina.png');
    background-repeat: no-repeat;
    background-position: center;
}

Live server
HTML file

答案1

得分: 0

尝试在路径中的文件夹之前添加点号(.)

@font-face {
font-family: Raleway;
src: url(./fonts/Raleway-Medium.ttf);
}
main{
background-image: url('./img/pozadina.png');
background-repeat: no-repeat;
background-position: center;
}

英文:

Try to add dots (.) before folders in path

@font-face {
  font-family: Raleway;
  src: url(./fonts/Raleway-Medium.ttf);
}
main{
  background-image: url('./img/pozadina.png');
  background-repeat: no-repeat;
  background-position: center;
}

答案2

得分: 0

I found the solution, instead of adding one dot I had to add two. Now it works for both, browser file protocol and live server.

<!-- begin snippet: js hide: false console: true babel: false -->

<!-- language: lang-css -->

@font-face {
font-family: Raleway;
src: url(../fonts/Raleway-Medium.ttf);
}
main{
background-image: url('../img/pozadina.png');
background-repeat: no-repeat;
background-position: center;
}

<!-- end snippet -->

英文:

I found the solution, instead of adding one dot i had to add two. Now it works for both, browser file protocol and live server.

<!-- begin snippet: js hide: false console: true babel: false -->

<!-- language: lang-css -->

@font-face {
  font-family: Raleway;
  src: url(../fonts/Raleway-Medium.ttf);
}
main{
  background-image: url(&#39;../img/pozadina.png&#39;);
  background-repeat: no-repeat;
  background-position: center;
}

<!-- end snippet -->

huangapple
  • 本文由 发表于 2023年2月16日 10:07:04
  • 转载请务必保留本文链接:https://go.coder-hub.com/75467162.html
匿名

发表评论

匿名网友

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

确定