Как исправить 'Аргумент типа' {} 'нельзя назначить параметру типа' any [] '.[ng] Свойство 'length' отсутствует в типе '{}'. ' - PullRequest
0 голосов
/ 27 марта 2019

Я собираюсь создать приложение Ionic Inventory Management со сканером штрих-кода и SQLite с помощью этого руководства: https://www.techiediaries.com/ionic-cordova-sqlite-barcode-scanner-product-inventory-manager/

Когда я добавлю этот код:

async createTables(){
    try {
        await this.database.executeSql(this.familyTable, {});
        await this.database.executeSql(this.locationTable,{});
        await this.database.executeSql(this.productTable,{});
        await this.database.executeSql(this.transactionTable,{});
    }catch(e){
        console.log("Error !");
    }
}

...to data-service.service.ts Я получил эту ошибку:

ОШИБКА в src / app / data-service.service.ts (54,64): ошибка TS2345: Аргумент типа '{} 'нельзя назначить параметру типа' any [] '.[ng] Свойство 'length' отсутствует в типе '{}'.[ng] src / app / data-service.service.ts (55,65): ошибка TS2345: Аргумент типа '{}' не может быть назначен параметру типа 'any []'.[ng] Свойство 'length' отсутствует в типе '{}'.[ng] src / app / data-service.service.ts (56,64): ошибка TS2345: Аргумент типа '{}' не может быть назначен параметру типа 'any []'.[ng] Свойство 'length' отсутствует в типе '{}'.[ng] src / app / data-service.service.ts (57,68): ошибка TS2345: Аргумент типа '{}' не может быть назначен параметру типа 'any []'.[ng] Свойство 'length' отсутствует в типе '{}'.

Это весь код data-service.service.ts:

import { Injectable } from '@angular/core';

import 'rxjs/add/operator/map';
import { SQLite, SQLiteObject } from '@ionic-native/sqlite/ngx';



@Injectable({
  providedIn: 'root'
})
export class DataServiceService {
  public database: SQLiteObject;

  productTable : string = `CREATE TABLE IF NOT EXISTS  products (
    id INTEGER PRIMARY KEY,
    sku TEXT,
    barcode TEXT,
    title TEXT NOT NULL,
    description TEXT,
    quantity REAL,
    unit VARCHAR,
    unitPrice REAL,
    minQuantity INTEGER,
    familly_id INTEGER,
    location_id INTEGER,
    FOREIGN KEY(familly_id) REFERENCES famillies(id),
    FOREIGN KEY(location_id) REFERENCES locations(id)
    );`;

familyTable : string = `CREATE TABLE IF NOT EXISTS famillies (
    id INTEGER PRIMARY KEY,
    reference VARCHAR(32) NOT NULL,
    name TEXT NOT NULL,
    unit VARCHAR);`;

locationTable : string = `CREATE TABLE IF NOT EXISTS locations (
        id INTEGER PRIMARY KEY,
        name TEXT NOT NULL);`;
//Date , Quantity , Unit Cost , Reason (New Stock - Usable Return - Unusable Return ) ,UPC (Universal Product Code ) Comment    
transactionTable : string = `CREATE TABLE IF NOT EXISTS transactions (
        id INTEGER PRIMARY KEY,
        date TEXT,
        quantity REAL,
        unitCost REAL,
        reason VARCHAR,
        upc TEXT,
        comment TEXT,
        product_id INTEGER,
        FOREIGN KEY(product_id) REFERENCES products(id));`;

        async createTables(){
          try {
              await this.database.executeSql(this.familyTable, {});
              await this.database.executeSql(this.locationTable,{});
              await this.database.executeSql(this.productTable,{});
              await this.database.executeSql(this.transactionTable,{});
          }catch(e){
              console.log("Error !");
          }
      }

        constructor(public sqlite :SQLite) {
          console.log('Hello DataServiceProvider Provider')

              this.sqlite.create({name: "data.db", location: "default"}).then((db : SQLiteObject) => {
                      this.database = db;
                  }, (error) => {
                      console.log("ERROR: ", error);
              }); 
    }

}

Есть ли у кого-нибудьидея как это исправить?

1 Ответ

2 голосов
/ 28 марта 2019

Подпись executeSql:

executeSql(statement: string, params?: any[]): Promise<any>;

Если вы вызываете executeSql с {} в качестве второго аргумента, я понимаю, что вы не хотите передавать какой-либо аргумент.Поэтому вы должны вызывать метод следующим образом:

await this.database.executeSql(this.familyTable);
await this.database.executeSql(this.locationTable);
await this.database.executeSql(this.productTable);
await this.database.executeSql(this.transactionTable);
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...