view source

JavaScript

var toSpaceLower = function(v){
  v = v.toLowerCase();
  v = v.replace(/([A-Z])/g, ' $1');
  v = v.replace(/[-_ ](.)/g, ' $1');
  v = v.replace(/  /g, ' ');
  //console.log(v);
  return v;
}

var toSpaceUpper = function(v){
  v = toSpaceLower(v);
  v = v.charAt(0).toUpperCase() + v.slice(1);
  v = v.replace(/ (.)/g, function(match, group1) {
      return " " + group1.toUpperCase();
  });
  return v;
}

var toCamel = function(v){
  v = toSpaceLower(v)
  //v = v.replace(/([A-Z]+)*([A-Z][a-z])/g, "$1 $2");
  return v.replace(/[-_ ](.)/g, function(match, group1) {
      return group1.toUpperCase();
  });
}
var toSnake = function(v){
  v = toCamel(v);
  return v.replace(/[A-Z]/g, function(s){
    return "_" + s.charAt(0).toLowerCase();
  });
}

var deleteSymbol = function(v){
  v = toCamel(v);
  return v.replace(/[!\.\?']/g, '');
}

$(function(){
  var wrap = $('#demo');
  var input =$('<textarea>').text('I am Robot.');
  var output =$('<textarea>');
  var btnCamel =$('<button>').text('CamelCase');
  var btnSnake =$('<button>').text('SnakeCase');
  var btnSpaceLower =$('<button>').text('SpaceLower');
  var btnSpaceUpper =$('<button>').text('SpaceUpper');
  var checkboxDelSymbol =$('<input>',{type:'checkbox'}).text('DelSymbol');

  wrap
    .append(input)
    .append(btnCamel)
    .append(btnSnake)
    .append(btnSpaceLower)
    .append(btnSpaceUpper)
    .append(checkboxDelSymbol)
    .append(output);

  btnCamel.on('click', function(){
    var v = input.val();
    v = toCamel(v)
    output.val(v)
  });
  btnSnake.on('click', function(){
    var v = input.val();
    v = toSnake(v)
    output.val(v)
  });
  btnSpaceLower.on('click', function(){
    var v = input.val();
    v = toSpaceLower(v)
    output.val(v)
  });
  btnSpaceUpper.on('click', function(){
    var v = input.val();
    v = toSpaceUpper(v)
    output.val(v)
  });


  input.on('input', function(){
    //output.val(v2);
  });
});

CSS

textarea{
  width:96%;
  height:200px;
}

HTML

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

view-source:https://hi0a.com/demo/-js/js-text-ConvertCamelCaseToSentenceCase/

ABOUT

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

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

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

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

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

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

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

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