저는 Twitter의 정적 스크립트를보고 모든 변수와 함수가 단지 1 문자 길이로 왜, 왜 그리고 어떻게해야하는지 알았습니까? 실적과 관련이 있습니까? 그렇다면 왜 웹 사이트의 모든 요소에 짧은 이름이 올지, 충돌을 피하기 위해 1 자 대신 2자를 길게 입력하는 것이 좋습니다.jQuery, JavaScript의 변수 및 함수에 대한 1 문자 이름
예 :
(function (A) {
A.fn.isScreenNameField = function() {
return this.each(function() {
var M = A(this);
var F = A("#signup_username_url");
var E = A("#screen_name_info");
var D = A("#avail_screenname_check_indicator");
var O;
var C;
var I;
var N = M.val();
var G = N;
var H = N != "";
var Q = /[a-zA-Z0-9_]/;
function K() {
if (H) {
F.html(M.val())
}
}
function L() {
M.trigger("show-info");
E.hide();
D.show()
}
function B() {
E.show();
D.hide()
}
function P() {
G = O;
jQuery.ajax({
type: "GET",
url: "https://stackoverflow.com/users/username_available",
data: {
username: O
},
dataType: "json",
success: function (R) {
if (C) {
var S = R.msg;
if (R.valid) {
M.trigger("is-valid");
F.removeClass("invalid").addClass("valid")
} else {
M.trigger("is-invalid", R.msg);
F.addClass("invalid").removeClass("valid")
}
}
},
beforeSend: null,
complete: function() {
clearTimeout(twttr.timeouts.availabilityTimeout);
B()
}
})
}
function J(R) {
O = M.val();
clearTimeout(twttr.timeouts.availabilityTimeout);
C = O.match(Q);
if (!C) {
G = O;
B();
return
}
if (O == G) {
return
}
L();
twttr.timeouts.availabilityTimeout = setTimeout(P, 2000)
}
M.isSignupFormField({
validateWith: function (R) {
if (isBlank(R)) {
return _("Please enter a user name")
} else {
P()
}
},
allowInput: Q
});
M.keyup(function (R) {
if (jQuery.inArray(R.keyCode, [16, 17, 18, 20, 27, 33, 34, 35, 37, 38, 39, 40, 144]) == -1) {
if (M.val() != "") {
H = true
} else {
M.trigger("show-info")
}
K();
J()
}
});
M.bind("value-changed", P);
M.bind("custom-validate", P)
})P
}
})
Crockford는이 특정 기술을 "난독 화"라고합니다. Crockford는 버그가 발생할 가능성이 너무 높기 때문에 난독 화를 싫어하기 때문에 JSMin은 변수 이름을 변경하지 않습니다. – Bob
좋은 지적입니다. [YUI Compressor] (http://developer.yahoo.com/yui/compressor/)는 모두 축소되고 "난독 화"됩니다. – kevingessner