Недійсний ініціалізатор властивостей скорочень


165

Я написав наступний код у JavaScript для проекту вузла, але зіткнувся з помилкою під час тестування модуля. Я не впевнений, що означає помилка. Ось мій код:

var http = require('http');
// makes an http request
var makeRequest = function(message) {
 var options = {
  host: 'localhost',
  port = 8080,
  path : '/',
  method: 'POST'
 }
 // make request and execute function on recieveing response
 var request = http.request(options, function(response) {
  response.on('data', function(data) {
    console.log(data);
  });
 });
 request.write(message);
 request.end();
}
module.exports = makeRequest;

Коли я намагаюся запустити цей модуль, він видає таку помилку:

$ node make_request.js
/home/pallab/Desktop/make_request.js:8
    path = '/',
    ^^^^^^^^^^
SyntaxError: Invalid shorthand property initializer
    at Object.exports.runInThisContext (vm.js:76:16)
    at Module._compile (module.js:542:28)
    at Object.Module._extensions..js (module.js:579:10)
    at Module.load (module.js:487:32)
    at tryModuleLoad (module.js:446:12)
    at Function.Module._load (module.js:438:3)
    at Module.runMain (module.js:604:10)
    at run (bootstrap_node.js:394:7)
    at startup (bootstrap_node.js:149:9)
    at bootstrap_node.js:509:3

Я не розумію, що це означає, і що я можу зробити, щоб вирішити це.

Відповіді:


443

Оскільки його об'єкт, використовується спосіб присвоєння значення його властивостям :.

Змініть =на, :щоб виправити помилку.

var options = {
  host: 'localhost',
  port: 8080,
  path: '/',
  method: 'POST'
 }

Це спрацювало, але я подумав, що ви використовуєте = для зберігання номерів і: для рядків
Pallab Ganguly

1
Див. Документи ініціалізатора об'єктів, щоб дізнатися, як ініціалізувати літерали об'єктів у JavaScript. Спеціально сесія під назвою Створення об'єктів .
Дієго Фарія

7
Я думав, що ви використовуєте =для зберігання номерів, а :для рядків я цікавлюсь, де б ви взяли цю ідею.

2
Архх! Час схопити каву. Дякую. :)
ArendE

5

Ця помилка, як правило, виникає, коли ви намагаєтеся призначити об'єкт зі знаком рівності (=), а не двокрапці (:)

Правильний код повинен бути таким: -

var options = {
  host: 'localhost',
  port: 8080,
  path: '/',
  method: 'POST'
 }

3

В параметрах об'єкта ви використовували знак "=" для присвоєння значенню порту, але ми повинні використовувати ":" для присвоєння значень властивостям в об'єкті при використанні об'єкта буквально для створення об'єкта, тобто "{}", ці фігурні дужки. Навіть коли ви використовуєте функцію вираження або створюєте об'єкт всередині об'єкта, ви повинні використовувати знак ":". наприклад:

    var rishabh = {
        class:"final year",
        roll:123,
        percent: function(marks1, marks2, marks3){
                      total = marks1 + marks2 + marks3;
                      this.percentage = total/3 }
                    };

john.percent(85,89,95);
console.log(rishabh.percentage);

тут ми маємо використовувати коми "," після кожного властивості. але ви можете використовувати інший стиль для створення та ініціалізації об'єкта.

var john = new Object():
john.father = "raja";  //1st way to assign using dot operator
john["mother"] = "rani";// 2nd way to assign using brackets and key must be string

1

Використовуйте :замість=

див. приклад нижче, що дає помилку

app.post('/mews', (req, res) => {
if (isValidMew(req.body)) {
    // insert into db
    const mew = {
        name = filter.clean(req.body.name.toString()),
        content = filter.clean(req.body.content.toString()),
        created: new Date()
    };

Це дає Syntex Error: неправильний короткочасний ініціалізатор proprty.

Тоді я замінити = з , :що вирішимо цю помилку.

app.post('/mews', (req, res) => {
if (isValidMew(req.body)) {
    // insert into db
    const mew = {
        name: filter.clean(req.body.name.toString()),
        content: filter.clean(req.body.content.toString()),
        created: new Date()
    };

-2

У вашій optionsініціалізації змінної є синтаксична помилка . Ви повинні використовувати port: 8080замість port = 8080.


Ця відповідь має бути коментарем, а не відповіддю :)
Піпету
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.