質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

Q&A

3回答

676閲覧

JavaScript ヘッダ部分をJavaScriptで出力させたい

jkut

総合スコア0

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

0グッド

0クリップ

投稿2020/07/16 01:18

前提・実現したいこと

JavaScriptでヘッダ部分を出力させたいのですがそのような事は可能でしょうか
document.write?append?innerHTML?可能なものなのでしょうか?

該当のソースコード

HTML

1document.write("<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> 2<html> 3<head> 4 <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> 5 <meta http-equiv="Content-Style-Type" content="text/css"> 6 <meta http-equiv="Content-Script-Type" content="text/javascript"> 7 <meta name="description" content=""> 8 <meta name="title" content=""> 9 <title></title> 10 <link href="/style/font_win.css?" rel="stylesheet" type="text/css"> 11 <link href="/style/style_minakoi.css?" rel="stylesheet" type="text/css">");

該当のソースコード

HTML

1test.innerHTML="<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> 2<html> 3<head> 4 <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> 5 <meta http-equiv="Content-Style-Type" content="text/css"> 6 <meta http-equiv="Content-Script-Type" content="text/javascript"> 7 <meta name="description" content=""> 8 <meta name="title" content=""> 9 <title></title> 10 <link href="/style/font_win.css?" rel="stylesheet" type="text/css"> 11 <link href="/style/style_minakoi.css?" rel="stylesheet" type="text/css">";

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

maisumakun

2020/07/16 01:20

何のためにそのようなことが必要となったのでしょうか?
jkut

2020/07/16 01:22

JavaScriptで全てのページ内容を仕上げられないかなと思いまして
jkut

2020/07/16 01:24

仮にできたとしてもSEO的にアウトになっちゃうんですかね
maisumakun

2020/07/16 01:24

それを呼ぶ<script>はどこに書くつもりでしょうか?
jkut

2020/07/16 01:26

外部ファイルです
maisumakun

2020/07/16 01:27

スクリプトの中身はいいのですが、それをどのようにしてブラウザから呼び出すのですか?
FrontEnd_Japan

2020/07/16 01:46

クローリングされるかされないかで言うとSEO的にはアウトです。
miyabi_takatsuk

2020/07/16 02:13 編集

FrontEnd_Japanさん > 一応、現代では、クローリングロボットもJavaScriptを実行できるため、実行後のWebページも評価されます。 title要素やその他の要素も評価対象かと。 おそらく、フロントエンドフレームワークによるSPAの台頭に対応した措置かと思われます。(ただしページ履歴を正当に制御したものに限ると思われる。また、その上でスパム対策は行われていると思われる) ですが、質問のコードだと、それ以前の問題ではありますが・・・。
guest

回答3

0

javascriptには要素を追加する関数が用意されているので、
headerのDOMを格納しているJSファイルを作成すればいけます。
タイミングとしては初期レンダリング時でも良いと思います。

lang="html"

1<div class="js-header"> 2 この中に<header>が展開される様に実装します。 3</div>

投稿2020/07/16 01:51

FrontEnd_Japan

総合スコア271

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

できないとは言いませんが、動作が安定するかは微妙です。
DOCTYPEのような基本で重要な要素はスタティックにHTML側で吐くか
サーバーサイドのプログラムで付加してください

投稿2020/07/16 01:50

yambejp

総合スコア116724

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

html

1<head id="headId"></head> 2 3<script> 4 var headTxt = ` 5 <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> 6 <meta http-equiv="Content-Style-Type" content="text/css"> 7 <meta http-equiv="Content-Script-Type" content="text/javascript"> 8 <meta name="description" content=""> 9 <meta name="title" content=""> 10 <title></title> 11 <link href="/style/font_win.css?" rel="stylesheet" type="text/css"> 12 <link href="/style/style_minakoi.css?" rel="stylesheet" type="text/css">"); 13 ` 14 let head = document.getElementById("headId") 15 head.innerHTML = headTxt 16 let _meta = document.createElement("meta") 17 _meta.httpEquiv = "Content-Style-Type" 18 _meta.content = "text/css" 19 head.appendChild(_meta) 20 let _meta2 = document.createElement("meta") 21 _meta2.httpEquiv = "Content-Script-Type" 22 _meta2.content = "text/javascript" 23 head.appendChild(_meta2) 24 let ch_meta = document.createElement("meta") 25 ch_meta.name = "description" 26 ch_meta.content = "" 27 let ch_meta2 = document.createElement("meta") 28 ch_meta2.name = "title" 29 ch_meta2.content = "" 30 _meta2.appendChild(ch_meta) 31 _meta2.appendChild(ch_meta2) 32 let title = document.createElement("title") 33 head.appendChild(title) 34 let _link = document.createElement("link") 35 _link.href="/style/font_win.css?" 36 _link.rel="stylesheet" 37 _link.type="text/css" 38 let _link2 = document.createElement("link") 39 _link2.href="/style/style_minakoi.css?" 40 _link2.rel="stylesheet" 41 _link2.type="text/css" 42 head.appendChild(_link) 43 head.appendChild(_link2) 44 45</script>

投稿2023/04/21 01:42

9nahito

総合スコア45

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問