[javascript] 자바 스크립트 문자열에 변수를 어떻게 넣습니까? (Node.js)

s = 'hello %s, how are you doing' % (my_name)

그것이 파이썬에서하는 방법입니다. javascript / node.js에서 어떻게 할 수 있습니까?



답변

비슷한 것을 원한다면 함수를 만들 수 있습니다.

function parse(str) {
    var args = [].slice.call(arguments, 1),
        i = 0;

    return str.replace(/%s/g, () => args[i++]);
}

용법:

s = parse('hello %s, how are you doing', my_name);

이것은 간단한 예일 뿐이며 다양한 데이터 유형 (예 %i: 등) 또는 이스케이프 처리를 고려하지 않습니다 %s. 그러나 나는 그것이 당신에게 아이디어를 줄 수 있기를 바랍니다. 나는 이와 같은 기능을 제공하는 라이브러리도 있다고 확신합니다.


답변

Node.js v4를 사용하면 ES6의 템플릿 문자열을 사용할 수 있습니다

var my_name = 'John';
var s = `hello ${my_name}, how are you doing`;
console.log(s); // prints hello John, how are you doing

문자열 `
대신 백틱으로 줄 바꿈해야합니다.'


답변

ES6을 사용하는 경우 템플릿 리터럴을 사용해야합니다.

//you can do this
let sentence = `My name is ${ user.name }. Nice to meet you.`

https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Template_literals에서 더 읽으십시오.


답변

현재 node.js >4.0문자열 조작이 크게 개선 된 ES6 표준과 더욱 호환됩니다.

대답은 원래의 질문은 간단하게 할 수 있습니다 :

var s = `hello ${my_name}, how are you doing`;
// note: tilt ` instead of single quote '

문자열이 여러 줄로 퍼질 수있는 경우 템플릿 또는 HTML / XML 프로세스를 매우 쉽게 만듭니다. 자세한 내용과 추가 기능 : 템플릿 리터럴은 mozilla.org의 문자열 리터럴 입니다.


답변

util.format이이를 수행합니다.

v0.5.3의 일부이며 다음 과 같이 사용할 수 있습니다.

var uri = util.format('http%s://%s%s',
      (useSSL?'s':''), apiBase, path||'/');


답변

그렇게:

s = 'hello ' + my_name + ', how are you doing'

최신 정보

ES6을 사용하면 다음을 수행 할 수도 있습니다.

s = `hello ${my_name}, how are you doing`


답변

String.prototypeES2015 템플릿 리터럴 을 확장 하거나 사용 하는 몇 가지 방법 .

var result = document.querySelector('#result');
// -----------------------------------------------------------------------------------
// Classic
String.prototype.format = String.prototype.format ||
  function () {
    var args = Array.prototype.slice.call(arguments);
    var replacer = function (a){return args[a.substr(1)-1];};
    return this.replace(/(\$\d+)/gm, replacer)
};
result.textContent =
  'hello $1, $2'.format('[world]', '[how are you?]');

// ES2015#1
'use strict'
String.prototype.format2 = String.prototype.format2 ||
  function(...merge) { return this.replace(/\$\d+/g, r => merge[r.slice(1)-1]); };
result.textContent += '\nHi there $1, $2'.format2('[sir]', '[I\'m fine, thnx]');

// ES2015#2: template literal
var merge = ['[good]', '[know]'];
result.textContent += `\nOk, ${merge[0]} to ${merge[1]}`;
<pre id="result"></pre>