웹 프론트엔드 HTML 튜토리얼 HTML_HTML/Xhtml_Web 페이지 제작 시 기본 태그 사용에 대한 자세한 설명

HTML_HTML/Xhtml_Web 페이지 제작 시 기본 태그 사용에 대한 자세한 설명

May 16, 2016 pm 04:40 PM
기본 태그 html

requireJS에는 baseURL이라는 속성이 있습니다. baseURL을 설정하면 현재 페이지가 아닌 프로젝트를 기준으로 로드할 파일의 경로를 작성할 수 있습니다.

예: 프로젝트 디렉토리가 /myproject/이고 그 안에 두 개의 페이지가 있다고 가정합니다. 하나는 /myproject/one.html이고 다른 하나는 /myproject/html/other.html이며 둘 다 /myproject를 로드해야 합니다. /js /some.js. baseURL을 /myproject/로 설정하면 js를 로드할 때 페이지 경로가 다르기 때문에 두 페이지 모두 다른 상대 경로를 사용하는 대신 project./js/some에 대한 상대 경로를 사용할 수 있습니다.

근데 requireJS를 사용하지 않으면 baseURL과 유사한 기능을 구현할 수 있나요?

기본 태그
사실 HTML에도 비슷한 기능을 할 수 있는 기본 태그가 있습니다. 예:

코드 복사
코드는 다음과 같습니다.

< html>
<head>
<base href="http://static.cnblogs.com/" />
</head>
<body>
<img src="./images/logo_gray.gif" />
</body>
</html>

상대 경로를 사용한다는 것을 알 수 있습니다. ./images /logo_gray.gif로 로드된 사진이 http://static.cnblogs.com/images/logo_gray.gif의 사진이 되었습니다.

base 태그는 페이지 링크에 기본 경로나 기본 열기 방법을 추가할 수 있습니다.

다음은 기본 개폐 방식 설정 예시입니다.

코드 복사
코드는 다음과 같습니다. :

<html>
<head>
<base target="_blank" />
</head></p> <p><body>
<a href="http://www.cnblogs.com">이 페이지는 새 창에서 열립니다</a>
<a href=" http://justany.cnblogs.com">이 페이지는 새 창에서도 열립니다</a>
</body>
</html>

버그
기본 태그를 동적으로 작성하지 않는 것이 가장 좋습니다. 그렇지 않으면 Firefox 및 IE에 http://localhost 페이지와 같은 작은 버그가 있을 수 있습니다. /static/test .html:

코드 복사
코드는 다음과 같습니다.



<script><br />document.write('<base href="http://localhost/" /&gt;');<br />&lt ;/script&gt;<br /> &lt;/head&gt;&lt;/p&gt; &lt;p&gt;&lt;body&gt;<br />&lt;img src="static/1.jpg" /&gt;<br />&lt;/body&gt;<br />&lt;/html&gt;<br /></script>

Firefox와 IE는 http://localhost/static/static/1.jpg를 먼저 로드한 다음 http://localhost/static/1.jpg를 로드합니다. 즉, 모두 현재 페이지를 기준으로 한 경로를 먼저 로드한 다음 기본 태그에 설정된 기본 경로를 통해 로드하려고 시도합니다.

Chrome이 정상적으로 로드됩니다.

Firefox가 제대로 로드되지 않습니다.

왜요?

이에 대한 마땅한 설명을 찾지 못했습니다. 브라우저가 리소스 로딩을 최적화했기 때문에 동적으로 삽입된 기본 태그가 적용되지 않을 경우 미리 로드되어 결과가 오류가 발생한다는 것입니다. 그러면 기본 태그가 적용됩니다. 올바른 리소스가 다시 로드됩니다.

어떻게 피할 수 있나요? 기본 태그를 동적으로 작성하지 않으면 문제가 없습니다. 기본 태그를 동적으로 작성해야 하는 경우 페이지에서 참조하는 모든 외부 리소스를 Javascript를 통해 동적으로 로드해야 합니다.

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

뜨거운 기사 태그

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

HTML의 중첩 테이블 HTML의 중첩 테이블 Sep 04, 2024 pm 04:49 PM

HTML의 중첩 테이블

HTML의 테이블 테두리 HTML의 테이블 테두리 Sep 04, 2024 pm 04:49 PM

HTML의 테이블 테두리

HTML 여백-왼쪽 HTML 여백-왼쪽 Sep 04, 2024 pm 04:48 PM

HTML 여백-왼쪽

HTML 테이블 레이아웃 HTML 테이블 레이아웃 Sep 04, 2024 pm 04:54 PM

HTML 테이블 레이아웃

HTML에서 텍스트 이동 HTML에서 텍스트 이동 Sep 04, 2024 pm 04:45 PM

HTML에서 텍스트 이동

HTML 정렬 목록 HTML 정렬 목록 Sep 04, 2024 pm 04:43 PM

HTML 정렬 목록

HTML 온클릭 버튼 HTML 온클릭 버튼 Sep 04, 2024 pm 04:49 PM

HTML 온클릭 버튼

PHP에서 HTML/XML을 어떻게 구문 분석하고 처리합니까? PHP에서 HTML/XML을 어떻게 구문 분석하고 처리합니까? Feb 07, 2025 am 11:57 AM

PHP에서 HTML/XML을 어떻게 구문 분석하고 처리합니까?

See all articles