Итак, у меня есть этот внутренний код:
Это admin.js:
let sql = `SELECT product_name, total_stock FROM inventory_tbl ORDER BY total_stock ASC LIMIT 10;`
db.query(sql, (error, gauge_results, fields) => {
let sql = `SELECT product_name, jacket_sold FROM inventory_tbl ORDER BY jacket_sold ASC LIMIT 10;`
var productname_array = [];
for (var i = 0; i < gauge_results.length; i++) {
productname_array.push(gauge_results[i].product_name);
}
var totalstock_array = [];
for (var i = 0; i < gauge_results.length; i++) {
totalstock_array.push(gauge_results[i].total_stock);
}
db.query(sql, (error, selling_results, fields) => {
let sql = `SELECT SUM(jacket_made) as jacketmade FROM inventory_tbl;`
db.query(sql, (error, jacket_made, fields) => {
let sql = `SELECT SUM(jacket_sold) as jacketsold FROM inventory_tbl;`
db.query(sql, (error, jacket_sold, fields) => {
let sql = `SELECT COUNT(transaction_no) as successfultrans FROM transaction_tbl WHERE status = 4 AND is_deleted = 0;`
db.query(sql, (error, successful_trans, fields) => {
let sql = `SELECT COUNT(stalltransaction_no) as stallcatered FROM stalltransaction_tbl;`
db.query(sql, (error, stall_catered, fields) => {
let sql = `SELECT * FROM inventory_tbl WHERE total_stock <= 10 ORDER BY total_stock ASC LIMIT 10;`
db.query(sql, (error, warning_results, fields) => {
let sql = `SELECT SUM(batch_cog * stock_left) as total_cogs FROM stocks_tbl WHERE stock_left != 0;`
db.query(sql, (error, costofgoods_result, fields) => {
console.log((costofgoods_result[0].total_cogs).toFixed(2));
console.log(productname_array);
console.log(totalstock_array);
// render to views/admin/dashboard.ejs template file
res.render('admin/dashboard', {
title: 'Perry in Disguise | Dashboard',
gauge_results: gauge_results,
selling_results: selling_results,
jacketmade: jacket_made[0].jacketmade,
jacketsold: jacket_sold[0].jacketsold,
successfultransaction: successful_trans[0].successfultrans,
eventcatered: stall_catered[0].stallcatered,
gauge_data: warning_results,
max_stocks: warning_results[warning_results.length - 1].total_stocks,
total_cogs: (costofgoods_result[0].total_cogs).toFixed(2),
productname: productname_array,
totalstock: totalstock_array
})
})
})
})
})
})
})
})
, и это код ejs, в котором я создал chartjs.
Dashboard.js:
<script>
let inventorygauge = document.getElementById('inventorygauge').getContext('2d')
let inventoryGaugeChart = new Chart(inventorygauge, {
type: 'horizontalBar',
data: {
label: <%= productname %> ,
datasets: [{
label: 'No. of Stocks',
data: [<%= totalstock %>]
}]
})
</script>
Что происходит, когда я отправляю массив (productname_array) в файл ejs, каким-то образом он теряет кавычки / экранирует кавычки.Я пытался удалить и добавить фигурные скобки, но это не сработало.Этот код теперь выводит данные без кавычек, поэтому он показывает: productname, productname, но это должно быть ['productname', 'productname'], что мне делать?