文字コードを変換する(SHIFT_JISやEUC-JPからUTF8へ)

view source

JavaScript

$(function(){
/*
//encoding-japaneseはget後判定の役には立たなかった
//https://github.com/polygonplanet/encoding.js/blob/master/README_ja.md
//https://cdnjs.com/libraries/encoding-japanese
  $.get('sjis.txt', function(data){
    $p = $('<p>').text(data);
    $('#demo').append($p);
    const codes = new Uint8Array(data);
    const encoding = Encoding.detect(codes);
    var ary = Encoding.stringToCode(data);
    console.log(ary);
    var detectedEncoding = Encoding.detect(encoding);
    $p2 = $('<p>').text(detectedEncoding);
    $('#demo').append($p2);
  });
  $.get('eucjp.txt', function(data){
    $p = $('<p>').text(data);
    $('#demo').append($p);
    const codes = new Uint8Array(data);
    const encoding = Encoding.detect(codes);
    var ary = Encoding.stringToCode(data);
    console.log(ary);
    var detectedEncoding = Encoding.detect(encoding);
    $p2 = $('<p>').text(detectedEncoding);
    $('#demo').append($p2);
  });
*/


  var getText = function(fileName){
    var charset = 'utf-8';
    if(fileName.match(/sjis/)){charset = 'shift_jis';}
    if(fileName.match(/euc/)){charset = 'euc-jp';}
    $.ajax({
        beforeSend : function(xhr) {
            xhr.overrideMimeType('text/plain; charset=' + charset);
        },
        url : fileName,
        dataType : 'text'
    }).done(function(data) {
      $a = $('<a>').text(fileName).attr({href:fileName});
      $p = $('<p>').text(data);
      $('#demo').append($p).append($a);
    });
  }

  getText('sjis.txt');
  getText('eucjp.txt');

});

CSS

HTML

ページのソースを表示 : Ctrl+U , DevTools : F12

view-source:https://hi0a.com/demo/-js/js-encoding-japanese/

ABOUT

hi0a.com 「ひまアプリ」は無料で遊べるミニゲームや便利ツールを公開しています。

プログラミング言語の動作デモやWEBデザイン、ソースコード、フロントエンド等の開発者のための技術を公開しています。

必要な機能の関数をコピペ利用したり勉強に活用できます。

プログラムの動作サンプル結果は画面上部に出力表示されています。

環境:最新のブラウザ GoogleChrome / Windows / Android / iPhone 等の端末で動作確認しています。

画像素材や音素材は半分自作でフリー素材配布サイトも利用しています。LINK参照。

動く便利なものが好きなだけで技術自体に興味はないのでコードは汚いです。

途中放置や実験状態、仕様変更、API廃止等で動かないページもあります。