[javascript] 자리 표시 자와 대체 개체를 사용하여 JavaScript 문자열 형식을 지정 하시겠습니까?

다음과 같은 문자열이 있습니다. My Name is %NAME% and my age is %AGE%.

%XXX%자리 표시 자입니다. 객체에서 값을 대체해야합니다.

개체는 다음과 같습니다. {"%NAME%":"Mike","%AGE%":"26","%EVENT%":"20"}

개체를 구문 분석하고 문자열을 해당 값으로 바꿔야합니다. 따라서 최종 출력은 다음과 같습니다.

제 이름은 Mike이고 나이는 26 세입니다.

모든 작업은 순수 자바 스크립트 또는 jquery를 사용하여 수행해야합니다.



답변

원래 질문의 요구 사항은 임의의 대체 키의 런타임 처리처럼 보이기 때문에 문자열 보간의 이점을 얻을 수 없었습니다.

그러나 문자열 보간 만 수행해야하는 경우 다음을 사용할 수 있습니다.

const str = `My name is ${replacements.name} and my age is ${replacements.age}.`

문자열을 구분하는 백틱은 필수입니다.


특정 OP의 요구 사항에 맞는 답변을 얻으 String.prototype.replace()려면 교체에 사용할 수 있습니다 .

다음 코드는 모든 일치 항목을 처리하고 교체하지 않은 항목은 터치하지 않습니다 (교체 값이 모두 문자열 인 경우 아래 참조).

var replacements = {"%NAME%":"Mike","%AGE%":"26","%EVENT%":"20"},
    str = 'My Name is %NAME% and my age is %AGE%.';

str = str.replace(/%\w+%/g, function(all) {
   return replacements[all] || all;
});

jsFiddle .

대체 항목 중 일부가 문자열이 아닌 경우 먼저 개체에 있는지 확인하십시오. 예와 같은 형식이있는 경우 (예 : 백분율 기호로 래핑) in연산자를 사용하여 이를 수행 할 수 있습니다 .

jsFiddle .

그러나 형식에 특수 형식 (예 : 문자열)이없고 교체 객체에 null프로토 타입 이없는 경우 Object.prototype.hasOwnProperty()잠재적으로 교체 된 하위 문자열이 프로토 타입의 속성 이름과 충돌하지 않는다고 보장 할 수없는 경우를 사용 합니다.

jsFiddle .

그렇지 않으면 대체 문자열이 'hasOwnProperty'이면 결과적으로 엉망인 문자열이 표시됩니다.

jsFiddle .


보조 노트로서, 당신은 호출해야 replacementsObject아닌가 Array.


답변

ES6 템플릿 리터럴을 사용하는 것은 어떻습니까?

var a = "cat";
var b = "fat";
console.log(`my ${a} is ${b}`); //notice back-ticked string

템플릿 리터럴에 대한 추가 정보 …


답변

JQuery (jquery.validate.js)를 사용하여 쉽게 작동 할 수 있습니다.

$.validator.format("My name is {0}, I'm {1} years old",["Bob","23"]);

또는 해당 기능 만 사용하려는 경우 해당 기능을 정의하고 다음과 같이 사용할 수 있습니다.

function format(source, params) {
    $.each(params,function (i, n) {
        source = source.replace(new RegExp("\\{" + i + "\\}", "g"), n);
    })
    return source;
}
alert(format("{0} is a {1}", ["Michael", "Guy"]));

jquery.validate.js 팀에 대한 크레딧


답변

최신 브라우저와 마찬가지로 자리 표시자는 C 스타일 기능과 유사한 새 버전의 Chrome / Firefox에서 지원됩니다 printf().

자리 표시 자 :

  • %s 끈.
  • %d, %i정수.
  • %f 부동 소수점 수.
  • %o 개체 하이퍼 링크.

console.log("generation 0:\t%f, %f, %f", a1a1, a1a2, a2a2);

BTW, 출력을 보려면 :

  • Chrome에서 바로 가기를 사용 Ctrl + Shift + J하거나 F12개발자 도구를 엽니 다.
  • Firefox에서는 바로 가기를 사용 Ctrl + Shift + K하거나 F12개발자 도구를 엽니 다.

@Update-nodejs 지원

nodejs는을 지원하지 않고 %f대신 %dnodejs에서 사용할 수 있습니다 . 함께 %d숫자뿐만 아니라 정수, 부동 숫자로 인쇄됩니다.


답변

그냥 사용 replace()

var values = {"%NAME%":"Mike","%AGE%":"26","%EVENT%":"20"};
var substitutedString = "My Name is %NAME% and my age is %AGE%.".replace("%NAME%", $values["%NAME%"]).replace("%AGE%", $values["%AGE%"]);


답변

다음과 같은 사용자 지정 바꾸기 기능을 사용할 수 있습니다.

var str = "My Name is %NAME% and my age is %AGE%.";
var replaceData = {"%NAME%":"Mike","%AGE%":"26","%EVENT%":"20"};

function substitute(str, data) {
    var output = str.replace(/%[^%]+%/g, function(match) {
        if (match in data) {
            return(data[match]);
        } else {
            return("");
        }
    });
    return(output);
}

var output = substitute(str, replaceData);

http://jsfiddle.net/jfriend00/DyCwk/에서 작동하는 것을 볼 수 있습니다 .


답변

% s 자리 표시자를 바꾸는 것과 같이 console.log에 더 가까운 작업을 수행하려면

>console.log("Hello %s how are you %s is everything %s?", "Loreto", "today", "allright")
>Hello Loreto how are you today is everything allright?

나는 이것을 썼다

function log() {
  var args = Array.prototype.slice.call(arguments);
  var rep= args.slice(1, args.length);
  var i=0;
  var output = args[0].replace(/%s/g, function(match,idx) {
    var subst=rep.slice(i, ++i);
    return( subst );
  });
   return(output);
}
res=log("Hello %s how are you %s is everything %s?", "Loreto", "today", "allright");
document.getElementById("console").innerHTML=res;
<span id="console"/>

당신은 얻을 것이다

>log("Hello %s how are you %s is everything %s?", "Loreto", "today", "allright")
>"Hello Loreto how are you today is everything allright?"

최신 정보

String.prototype문자열 변환을 다룰 때 유용한 간단한 변형을 추가 했습니다. 다음은 다음과 같습니다.

String.prototype.log = function() {
    var args = Array.prototype.slice.call(arguments);
    var rep= args.slice(0, args.length);
    var i=0;
    var output = this.replace(/%s|%d|%f|%@/g, function(match,idx) {
      var subst=rep.slice(i, ++i);
      return( subst );
    });
    return output;
   }

이 경우 당신은 할 것입니다

"Hello %s how are you %s is everything %s?".log("Loreto", "today", "allright")
"Hello Loreto how are you today is everything allright?"

여기 에서이 버전을 사용해보세요