답변:
내가 얻을 수있는 가장 짧은 것은 다음과 같습니다.
<script>document.write(new Date().getFullYear())</script>
그것은 내가 실행 한 모든 브라우저에서 작동합니다.
내가 도착한 방법 :
getFullYear새로 생성 된을 직접 호출 할 수 있습니다 Date. new Date().getFullYear()조금 이상하게 보일지 모르지만 신뢰할 만합니다. new Date()부분이 먼저 수행 된 다음 .getFullYear().typeJavaScript가 기본값이므로을 (를) 삭제할 수 있습니다 . 이것은 심지어 HTML5 사양의 일부로 문서화되어 있으며 ,이 경우 브라우저가 이미 수행 한 작업을 작성하고있을 가능성이 있습니다.JavaScript가 활성화 된 브라우저에서만 작동합니다. 이상적으로는 일 sed년에 한 번 오프라인 배치 작업 ( * nix의 스크립트 등)으로 처리하는 것이 더 좋지만 JavaScript 솔루션을 원한다면 최대한 짧습니다. (이제 나는 운명에 가고 유혹했다.)
document.write초기 구문 분석 단계 (위에 표시된 것처럼 <script>...</script>태그 또는 태그 가 있거나 .js로드 되지 않은 파일) 에서 인라인 컨텐츠 에만 사용할 수 있습니다 . 페이지가 완전히 구문 분석되면 문서 스트림이 닫히고 다시 열면 문서가 새 것으로 대체됩니다. 기본 구문 분석이 완료된 후 1 년을 추가하려면 DOM을 사용하려고합니다. (이것은 변화가 아니며 항상 이런 식으로 진행되었습니다.)script deferasyncdocument.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.writeDOM이 이미로드 된 후에 사용 된 것입니다. 해결책은 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();