これは私を何時間も怒らせてきました。単純なものが欠けているか、そうでないかもしれません。
Javascript を使用して、個人のホームページをコンソールのようなアプリケーションに変えています。ここで見ることができます: www.fort-hub.com
私はキーストロークをマッピングしており、バックスペース (キーコード 8) を使用して、呼び出されinnerHTML
たコンソール入力のプロパティを変更し、次のように終了文字を 1 つ少なくしています。div
#in
slice()
HTML:
<!doctype html>
<html lang='en-gb'>
<head>
<meta charset="UTF-8">
<title>FortHUB</title>
<link href="ss.css" rel="stylesheet" type="text/css">
<meta name="viewport" content="width=device-width; initial-scale=1.0; maximum-scale=1.0;">
</head>
<body>
<div id="console">
<div id="out"><h1>Welcome to fort-hub console</h1></div>
<div id="in">
<span id="text"></span><span id="cursor"><</span>
</div>
</div>
<script src="fH.js"></script>
</body>
</html>
Javascript:
/* Globals */
var _NL_ = '>';
var consoleIn = document.getElementById('text');
var consoleOut = document.getElementById('out');
/* Func in question */
function keyPress(event)
{
event.preventDefault();
event.stopPropagation();
var e = event || window.event;
var key = e.which || e.keyCode;
var keyChar;
var allowedChars = new Array();
allowedChars[0] = 8; /* backspace */
allowedChars[1] = 13; /* return */
allowedChars[2] = 32; /* space */
/* Alphanumeric range only */
if(key > 46 && key < 90 || inArray(allowedChars, key) === true)
{
keyChar = String.fromCharCode(key);
var input = trim(consoleIn.innerHTML);
/* Map backspace */
if(key === 8)
{
consoleIn.innerHTML = input.slice(0, -1);
}
...
consoleIn.innerHTML += keyChar.toLowerCase();
}
...
}
そのため、URL に移動し、何かを入力してバックスペースを押して、これをテストしてください。1 文字が削除されますが、バックスペースを繰り返しても文字列の残りの文字は削除されません。