답변:
내가 얻을 수있는 가장 짧은 것은 다음과 같습니다.
<script>document.write(new Date().getFullYear())</script>
그것은 내가 실행 한 모든 브라우저에서 작동합니다.
내가 도착한 방법 :
getFullYear
새로 생성 된을 직접 호출 할 수 있습니다 Date
. new Date().getFullYear()
조금 이상하게 보일지 모르지만 신뢰할 만합니다. new Date()
부분이 먼저 수행 된 다음 .getFullYear()
.type
JavaScript가 기본값이므로을 (를) 삭제할 수 있습니다 . 이것은 심지어 HTML5 사양의 일부로 문서화되어 있으며 ,이 경우 브라우저가 이미 수행 한 작업을 작성하고있을 가능성이 있습니다.JavaScript가 활성화 된 브라우저에서만 작동합니다. 이상적으로는 일 sed
년에 한 번 오프라인 배치 작업 ( * nix의 스크립트 등)으로 처리하는 것이 더 좋지만 JavaScript 솔루션을 원한다면 최대한 짧습니다. (이제 나는 운명에 가고 유혹했다.)
document.write
초기 구문 분석 단계 (위에 표시된 것처럼 <script>...</script>
태그 또는 태그 가 있거나 .js
로드 되지 않은 파일) 에서 인라인 컨텐츠 에만 사용할 수 있습니다 . 페이지가 완전히 구문 분석되면 문서 스트림이 닫히고 다시 열면 문서가 새 것으로 대체됩니다. 기본 구문 분석이 완료된 후 1 년을 추가하려면 DOM을 사용하려고합니다. (이것은 변화가 아니며 항상 이런 식으로 진행되었습니다.)script
defer
async
document.write
TJ의 대답은 훌륭하지만 HTML이 이미 렌더링되고 document.write 스크립트가 모든 페이지 내용을 날짜 연도로 덮어 쓰는 하나의 시나리오에 부딪 쳤습니다.
이 시나리오에서는 다음 코드를 사용하여 기존 요소에 텍스트 노드를 추가 할 수 있습니다.
<div>
©
<span id="copyright">
<script>document.getElementById('copyright').appendChild(document.createTextNode(new Date().getFullYear()))</script>
</span>
Company Name
</div>
createTextNode()
<br>
HTML로 노드를 만드는 방법 과 같이 HTML을 해석하지 않습니까?
내년에 현재 연도 (예 : 2017)를 시작 연도로 사용하여 미래에 시간 프레임을 포함 시키려면 다음과 같이 표시됩니다 : "© 2017-2018, Company.", 다음 코드를 사용하십시오. . 매년 자동으로 업데이트됩니다.
© Copyright 2017<script>new Date().getFullYear()>2017&&document.write("-"+new Date().getFullYear());</script>, Company.
© 저작권 2017-2018, 회사.
그러나 첫해가 이미 지났다면 가장 짧은 코드는 다음과 같이 작성할 수 있습니다.
© Copyright 2010-<script>document.write(new Date().getFullYear())</script>, Company.
JS 솔루션은 훌륭하게 작동하지만 서버 측 솔루션에 대해 조언합니다. 내가 확인한 사이트 중 일부는 전체 페이지가 비어있는 문제가 있었고 한 해만 한 번만 보였습니다.
그 이유는 document.write가 실제로 전체 문서를 작성 했기 때문입니다 .
나는 친구에게 서버 측 솔루션을 구현하도록 요청했으며 그에게 도움이되었습니다. PHP의 간단한 코드
<?php echo date('Y'); ?>
즐겨!
document.write
DOM이 이미로드 된 후에 사용 된 것입니다. 해결책은 document.write
모든 DOM이로드 된 후에 는 사용하지 않거나 전혀 사용 하지 않는 document.write
것입니다.
AD와 BC 모두에서 작동하는 가장 짧은 가장 책임있는 버전은 다음과 같습니다.
[드럼 롤 ...]
<script>document.write(Date().split` `[3])</script>
그게 다야. 허용 된 답변보다 6 바이트 짧은.
ES5와 호환 가능해야하는 경우 다음과 같이 해결할 수 있습니다.
<script>document.write(Date().split(' ')[3])</script>
이것이 내가 생각할 수있는 가장 좋은 해결책은 순수한 JavaScript와 함께 작동한다는 것입니다. CSS에서 타겟팅 할 수있는 요소의 스타일을 지정할 수도 있습니다. 연도 대신 추가하면 자동으로 업데이트됩니다.
//Wait for everything to load first
window.addEventListener('load', () => {
//Wrap code in IIFE
(function() {
//If your page has an element with ID of auto-year-update the element will be populated with the current year.
var date = new Date();
if (document.querySelector("#auto-year-update") !== null) {
document.querySelector("#auto-year-update").innerText = date.getFullYear();
}
})();
});
<div>©<script>document.write(new Date().getFullYear());</script>, Company.
</div>
크롬 감사에 따르면
연결 속도가 느린 사용자의 경우 동적으로 삽입 된 외부 스크립트
document.write()
는 페이지로드를 수십 초 지연시킬 수 있습니다.https://web.dev/no-document-write/?utm_source=lighthouse&utm_medium=devtools
오류가없는 솔루션은 다음과 같습니다.
(new Date).getFullYear();