Dreamweaver

文字コード変換

記述方法は間違いないのに、文字化けしてしまう。

xhtmlはutf-8で宣言していたのだが、Javascriptで記述された日本語がブラウザで確認すると文字化けしてしまった。

「なぜ?」

もう少し試して分かったことは、xhtml内に直接書いたスクリプトでは文字化けしない。それを外部化すると文字化けすることが分かった。

文字コード宣言していないからいけないのだろうか?

例えばスタイルシートでは先頭に「@charset〜」を記述するが、javascriptの場合はどうなのだろう?
ネットサーフィンして分かったことは、もともとJavascriptはutf-8で認識される。・・・。よく分からん。ものは試し、とりあえずxhtmlソース内のスクリプト部分に「charaset="shift-jis"」を追加してみる。

<script type="text/javascript" src="test.js" charaset="shift-jis"></script>

「文字化けしてない!」

これで一見落着と思ったが、よくよく考えて奇妙な疑問にぶち当る。

なぜ、xhtmlのutf-8で書かれた日本語は正しく解釈されていて、javascriptのutf-8は文字化けしてしまうのだろうか?

そもそも根本的な事柄として、utf-8とshift-jisの違いを含めた文字コードを調べてみる。

Shift_JIS
日本語コード。通常、WindowsやMacintoshで取り扱う文字コード
EUC-JP
日本語コード。UNIXで日本語をサポートする文字コード
iso2022-jp
日本語コード。単にJISとも呼ばれる。日本語コードの基本となるもので、HTML以外にも電子メールなどに使われる。
UTF-8
各国の文字、アクセント記号、漢字の利用が可能。ただしブラウザによっては間違った表示がなされることもある
ASCII
アメリカの標準の文字コード。すべてのコードの基本となる、アルファベットや記号が含まれる
ISO-8859-1
西洋諸語コード。Laten1と呼ばれる文字コード。LatinコードにはLatin1からLatin10までがあり、Latin1ではカバーしきれない言語や記号に対応できるようになっている

ふむふむ、utf-8で漢字の利用ができる。つまり、Javascriptの文字コードがutf-8でも問題はないはずなのだ。

制作の段階で、果たしてほんとにUTF-8で書かれていただろうか?

utf-8で呼び出したはずの文が文字化けしているということは、そもそも制作段階で果たしてほんとにutf-8で保存されているのだろうか?という新たな疑問にぶちあたった。

問題の解決の糸口はここにあった。

確認したところ、外部ファイルで容易したJavascriptファイル自体が、実はShift-JISで保存されていたのだ。だから、utf-8で書かれた外部ファイルを呼び出すと、文字化けしてしまい、shift-jisで呼び出すと、文字化けが直っていたのである。

Dreamweaverで文字コードを変換する

つまり、utf-8で呼び出すには、スクリプト自体もutf-8で制作する必要があったのだ。
今にして思えば当たり前のことだが・・・。お恥ずかしい限り。
最後にDreamweaverでの文字コードの設定方法を紹介しておく。

新規で制作するファイルの文字コード設定方法

「環境設定」>新規ドキュメント>エンコーディングの設定

すでに制作されたファイルの文字コード変換方法

  1. 修正したいファイルを開く
  2. 「コマンド」+「J」
  3. 任意の文字コードを選択

最近の記事

cronっぽいことをPHPでjsonとして実装する

外部のAPIを利用する際、リクエスト回数が制限されることがある。また、リクエスト回数が制限され、かつ毎日更新をルールとする外部のAPIもある。 そんなと・・・

php

Instagram API を使ってインスタに投稿した画像データを取得する

インスタに投稿した画像を自動でホームページでも更新されるようにしたい。もっとも簡単に実現する方法を紹介する。 公式リファレンスInstagram・・・

API

名刺代わりの超絶ミニマムなブランディングページ

このたび、ハンドメイドアクセサリー作家さんのWebサイト制作させていただきました! Sunny Side Accessory(サニーサイド アクセサリー・・・

お仕事・制作日記

案件、承っております

2021年2月現在、案件承っております。とくに短期、週2、3日での外注をお考えでしたら、ぜひご連絡ください。 当方、2015年2月より「シンプルシンプル・・・

お仕事・制作日記

インタラクションデザイン

5年くらい前に購入した書籍「インタラクションデザイン」。この書籍内ではたくさんの事例が紹介されている。残念ながらその多くは現在閲覧することができなくなっていた・・・

デザイン

Advanced Custom Fields 名前を変更して、データも反映させる

WordPressを自作する上でもはや欠かせないプラグインの一つが、「Advanced Custom Fields」。 名前を変更しようと思って、Wor・・・

WordPress

配列の重複を削除する

配列の場合 /** * 配列の重複を削除する * * @param {array} ary* * @return {array} 処理後のary・・・

JavaScript

MAMP を 5.7 から 6.2 にアップデートした

5年以上前と比べると、アップデートが簡単で驚く。とくに記事にするまでもないと思いつつ、一応備忘録。 インストールすると、既存のディレクトリはそのままに別・・・

MAMP

Briefly unavailable for scheduled maintenance. Check back in a minute. → . maintenance を削除

プラグインを更新中に、誤って、違うページにアクセスしまいました。すると、管理画面だけでなく、公開中のすべての画面が「briefly unavailable f・・・

WordPress

GulpでERRが出てテンパった → gyp: No Xcode or CLT version detected! → PostCSS plugin autoprefixer requires PostCSS 8

Gulp。いつもは正常に動いている環境をそのままコピーして再利用するようにしている。そうすることで、案件ごとに毎回環境作りをする手間を省くことができ、何よりG・・・

制作効率化

人気の記事

WP_Queryを使って絞り込み検索するのにコレは便利!

めっちゃ参考になるページを見つけた。 絞り込みをするたびに色々ググっていたが、これがあればほとんどのことが解決できそうな気がする。 参考: これは便利!Word・・・

WordPress

overflowをautoにした要素のスクロール位置を変更する → scrollTop scrollLeft

まずはサンプル。 これは、overflowをautoにした要素のスクロール位置を変更するサンプルです。 これは、overflowをautoにした要素のスクロ・・・

JavaScript

iframeの高さを自動調整する

iframeで呼び出した際、iframe自体はスクロールさせずに高さを取得してiframe全体を表示させます。 サンプル:iframeの高さを自動調整するデモ・・・

JavaScript

http://localhost:8888/ → http://localhost/

http://localhost:8888/ での参照ではなく、http://localhost/ で参照できるようにします。 MAMPの設定を変更する M・・・

MAMP

アーカイブページでカスタムフィールドやタクソノミーで絞り込みした状態でリスト表示する

<?php $args = array( 'paged' => 1, 'posts_per_page' => 20, 'post・・・

WordPress

カウントアップ、カウントダウンするJavaScript

ポイントを使ったり、増やしたりしたときに、結果のポイント数に差し替えるのではなくて、カウントアップしたり、カウントダウンして動的に動かそうと思って作ってみた。・・・

JavaScript

WordPressのカテゴリー一覧ページでカテゴリー名とスラッグを取得する → get_queried_object()

やりたいこと カテゴリー一覧ページで、そのカテゴリー一覧ページに属する記事一覧を取得するためにループさせるのとは別に、タイトルやカテゴリー別にデザインを変・・・

WordPress

イラストレーターでレイヤーごとにPNGで書き出す

【2020年07月13日】 macOS Catalina(10.15.5) / Adobe iLLustrator 2020(24.2.1) にて動作確認済・・・

Illustorator

管理画面のカスタム投稿一覧で並び順を変更する

WordPressの管理画面。「投稿」や「固定ページ」の一覧は、公開日順に並んでいる。ところが、カスタム投稿を追加した場合、公開順ではなく名前順に並んでいること・・・

WordPress

MAMPの日時(タイムゾーン)を変更する

MAMPを使用していて、日時の情報を制御しようとしたとき、取得している日時が日本時間ではないことに気がついた。 時差を計算してPHPでプログラミングしていたが、・・・

MAMP

WEB制作アプリケーションDreamweaver文字コード変換 | シンプルシンプルデザイン