[解決済み] 配列の結合時に未定義のプロパティ 'push' を読み込むことができない
2021-12-28 13:49:11
質問
配列の内容を別の配列にプッシュしたいのですが、以下のようなコードです。
var order = new Object(), stack = [];
for(var i=0;i<a.length;i++){
if(parseInt(a[i].daysleft) == 0){ order[0].push(a[i]); }
if(parseInt(a[i].daysleft) > 0){ order[1].push(a[i]); }
if(parseInt(a[i].daysleft) < 0){ order[2].push(a[i]); }
}
2番目のifでエラーが発生します。
"Uncaught TypeError: Cannot read property 'push' of undefined" error in this snippet.
解決方法は?
エラーが発生した理由
order[1]
は
undefined
.
このエラーメッセージは、コードのどこかで、ある名前(ここでは "push" )を持つプロパティにアクセスしようとしているが、オブジェクトではなく、参照のベースが実際にあることを意味しています。
undefined
. したがって、問題を見つけるには、そのプロパティ名("push")を参照しているコードを探し、その左側にあるものを確認することになるのです。この場合、そのコードは
if(parseInt(a[i].daysleft) > 0){ order[1].push(a[i]); }
ということは、このコードが期待するのは
order[1]
は配列である。しかし、それは
ではない
配列です。
undefined
というエラーが発生します。なぜ、それは
undefined
? ご質問の内容からすると、あなたのコードは何もしていませんね。
さて、もしあなたがただ
a[i]
をオブジェクトの特定のプロパティで呼び出す必要はありません。
.push()
を全く使用しない。
var order = [], stack = [];
for(var i=0;i<a.length;i++){
if(parseInt(a[i].daysleft) == 0){ order[0] = a[i]; }
if(parseInt(a[i].daysleft) > 0){ order[1] = a[i]; }
if(parseInt(a[i].daysleft) < 0){ order[2] = a[i]; }
}
関連
-
要素ツリー制御によるvueTreeテーブル
-
Vueのフォームイベントのデータバインディングの説明
-
[解決済み】Uncaught SyntaxError: JSONの位置0に予期しないトークンuがあります。
-
[解決済み】GETできない / Nodejsエラー
-
[解決済み] Uncaught TypeError: 未定義のプロパティ 'toLowerCase' を読み取れませんでした。
-
[解決済み] JavaScript - 未定義のプロパティを設定することはできません。
-
[解決済み] ES6インポートで中括弧を使用するのはどのような場合ですか?
-
[解決済み] React - uncaught TypeError: 未定義のプロパティ 'setState' を読み取れない
-
[解決済み】未定義のオブジェクトプロパティを検出する
-
[解決済み】JavaScriptで何かが未定義でないかをテストする
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
JSクロスドメインソリューション リアクト構成 リバースプロキシ
-
JavaScriptの関数この指摘の問題を説明
-
Vue+ElementUIによる大規模なフォームの処理例
-
jQueryのコピーオブジェクトの説明
-
vueにおけるfilterの適用シーンについて解説します。
-
Vueのフィルタの説明
-
[解決済み】ExpressJS - throw er Unhandled errorイベント
-
フロントエンド null のプロパティ 'disabled' を読み取れない 問題が解決された
-
OSSアップロードエラーを解決する: net::ERR_SSL_PROTOCOL_ERROR
-
[解決済み] Javascriptのオブジェクトpush()関数