2ちゃんねる ■掲示板に戻る■ 全部 1- 最新50    

■ このスレッドは過去ログ倉庫に格納されています

JavaScript の質問用スレッド vol.125

1 :デフォルトの名無しさん :2022/08/07(日) 15:57:40.26 ID:TS5TGpUB0.net
!extend:checked:vvvvvv:1000:512
JavaScript を自ら学ぶ人のための質問スレッドです。
>>2-5のテンプレを読んだ上で質問してください。次スレは>>950>>2の「次スレの立て方」を元に立ててください

■質問を書く上で
(1) 煽り、コード制作依頼等、人を不快にさせる投稿はご遠慮下さい。公序良俗を守った応対を心がけてください。
(2) 他の人に迷惑をかけるスクリプトの質問はご遠慮ください。
  (ブラクラ、[戻る], [閉じる], [クリック] の妨害、画面占有など)
(3) 質問者及び議論を行う人はメール欄を空欄にし、名前にレス番を入れることを強く推奨します。回答者はなりすましを判断できませんので、なりすましが現れても自己責任となります。
(4) 常に自発的に調べる心構えを持ってください。
  具体的には「自分で調べてから質問する」「回答をもらってわからない単語があればGoogle検索してみる」など。
  わからない内容を代わりに調べてくれる回答者をお望みの方は余所で質問してください。
(5) 出来るだけ一般的な用語を使用してください。脳内オレオレ用語は混乱の元です。
(6) 出来るだけサンプルコードを掲示してください。言葉による説明は行き違いが生まれる場合があります。
  ※必ず「問題の事象が再現されること」を確認してください。
   必要な部分だけ切り出したつもりで現象が再現できていなかったケアレスミスがしばしば見られます。
(7) サンプルコードに HTML が含まれる場合は http://validator.w3.org/ で [Check] してみてください。
(8) 質問を具体的かつ詳細に書くと回答を得られやすいです。>>2の質問テンプレートを活用してみてください。
(9) ライブラリ関連の質問は禁止です。関連スレにあるライブラリ質問スレで質問して下さい。
(10) 時にはあなたが望む「答え」だけでなく、「意見」などが寄せられる場合もあります。

■前スレ
JavaScript の質問用スレッド vol.124
https://mevius.5ch.net/test/read.cgi/tech/1636525464/
VIPQ2_EXTDAT: checked:vvvvvv:1000:512:: EXT was configured

955 :デフォルトの名無しさん :2023/11/20(月) 16:19:56.96 ID:q8v/AXQl0.net
const arr =Array(3).fill([]);
arr[1].push(0);
console.log(arr);

この場合arrは[[], [0],[]]になっていることを期待するのですが実際には[[0], [0], [0]]となっています
まったく納得いかないのですがなぜですか

956 :デフォルトの名無しさん :2023/11/20(月) 16:41:25.42 ID:LC62eXy40.net
>>955
https://developer.mozilla.org/ja/docs/Web/JavaScript/Reference/Global_Objects/Array/fill#value
>配列を埋める値。もし value がオブジェクトであれば、配列のそれぞれの要素はそのオブジェクトを参照します。

957 :デフォルトの名無しさん :2023/11/20(月) 16:49:32.78 ID:q8v/AXQl0.net
>>956
fillがそういう仕様なんですね
納得です
ありがとうございました

958 :デフォルトの名無しさん (ワッチョイ eb79-5mk2 [2400:2200:7f6:ca17:*]):2023/11/21(火) 08:31:09.87 ID:reAksYQu0.net
いえいえ

959 :デフォルトの名無しさん :2023/11/21(火) 23:06:08.47 ID:Hk8WzggI0.net
変数宣言の際に、letよりconstを積極的に使うべき、とされているのはなぜでしょうか?
後で値を変えられるletの方が便利だと思うのですが

960 :デフォルトの名無しさん :2023/11/22(水) 00:26:41.03 ID:nlRha+4K0.net
JSにかかわらず変数は使ってる道中に値変換したり変数使いまわしてるとエラーの種になりやすいし、それを防止するのが大きいかな
配列やオブジェクトの値はconstでも変えられるし

昔はそういうごちゃごちゃ動く変数のトレースするのもプログラム組むやつの能力ってされてたなぁ

961 :デフォルトの名無しさん :2023/11/22(水) 03:01:31.39 ID:KDSVu4Ne0.net
コードを上から読んでいく時にconstだとこの値は後から変わることがないと決めつけて読むことができる
letだとどこかで書き換えられるのに注意しながら読まないといけない

962 :デフォルトの名無しさん :2023/11/22(水) 10:49:23.49 ID:5A+ZhXZi0.net
可読性の部分が大きいよね
varで変数定義しているクソコードなんかリファクタリングしたくないだろ?

963 :デフォルトの名無しさん :2023/11/22(水) 11:06:59.29 ID:5A+ZhXZi0.net
constで最初から定義した後にそれが動的な値だった場合タイプエラーを起こしてからletに書き換える事はあるけど最初からletで定義しちゃうと後々constに書き換えた場合もしそれが動的な値ならプログラムそのものが動かなくなって新たなるバグを生むでしょう?
最初は縛りを強くしておいて後から緩めるはあるけど逆はないですよ

964 :デフォルトの名無しさん :2023/11/22(水) 15:03:20.05 ID:hF+LjdVs0.net
条件によって const の値を変えられるようになるといいんだけどな。
簡単なのなら参考演算子でやれるけど。

965 :デフォルトの名無しさん (ワッチョイ e302-8oJ/ [27.94.242.45]):2023/11/22(水) 20:15:59.75 ID:5A+ZhXZi0.net
>>964
よくわからないけどそれってconst使う意味あるの?

966 :デフォルトの名無しさん (ワッチョイ 2539-YW6P [2400:2200:6f2:ad2b:*]):2023/11/22(水) 20:54:04.80 ID:FIiKhTS50.net
察するに初期代入時に場合によって違う値を入れたいということだろう
三項演算子を出してるし

967 :956 (ワッチョイ 4d1d-f5/H [180.178.89.53]):2023/11/22(水) 21:26:20.43 ID:VeafCB/q0.net
答えてくれた方々ありがとうございました
積極的にconstを使っていきたいと思います

968 :デフォルトの名無しさん (ワッチョイ 25ca-SdNv [122.132.80.240]):2023/11/22(水) 21:54:03.90 ID:7CtxEw9g0.net
>>965
うまい例になってるかわからないけど、何かのプロパティに値が入ってたらそれ、無ければデフォルト値を const に入れたいとか、この条件がもっと複雑になった感じとか。
あるいは、何かの基準座標を const に入れたいけどその値は一発では求まらないとか。
単にこれだけなら中間的な変数を使って値を求めて、最後に const に代入するって手もあるだろうけど、中間的な変数はスコープから追い出したいのにできないよね。

const x;
{
let a, b, c;
:
x = a + b * c;
}

みたいにできれば a b c はスコープから追い出せるけど、実際は

let a, b, c;
:
const x = a + b * c;

ってやらざるを得なくて、x が存在するスコープから a b c を追い出せない。
この計算を function に切り出せよと言うかもしれないけど、できればそうすりゃいいけどどこにでも適用できるというわけでもない。

969 :デフォルトの名無しさん (ワッチョイ 250c-YW6P [2400:2200:6d0:af1d:*]):2023/11/22(水) 22:23:44.12 ID:lZKHNjwl0.net
調べてみると苦肉の策で↓みたいな書き方が紹介されてたけど可読性考えるとどうだろうね
const x = (() => {
let a, b, c;
:
return a + b * c;
})();

970 :デフォルトの名無しさん (ワッチョイ e3c2-fy5B [2001:240:2467:98ce:*]):2023/11/22(水) 22:52:37.25 ID:8gAUwwkj0.net
関数に切り出さない意味がわからない

971 :デフォルトの名無しさん (ワッチョイ 6bcf-ekUX [153.206.41.110]):2023/11/23(木) 00:25:34.14 ID:9np+Rtrn0.net
欲しいのはただのブロックなのに関数として書かなければならないというのが余計なことをやらされている感はある。

972 :デフォルトの名無しさん :2023/11/23(木) 01:53:09.12 ID:pAGXWPD10.net
var使え

973 :デフォルトの名無しさん (ワッチョイ 25ca-SdNv [122.132.80.240]):2023/11/23(木) 15:16:53.54 ID:d47OCYFA0.net
>>969
処理の結果として複数の const、例えば x y を求めたい時は、その書き方でも難があるよね

974 :デフォルトの名無しさん (ワッチョイ 2d12-YW6P [2400:2200:6f7:92d9:*]):2023/11/23(木) 15:39:42.20 ID:98Thj8w70.net
>>973
その場合はタプルで受け取るようにすれば問題ないよ
const [x, y] = (() => {
let a, b, c;
:
return [a + b * c, a * b + c];
})();

975 :デフォルトの名無しさん (ワッチョイ 25ca-SdNv [122.132.80.240]):2023/11/23(木) 15:58:06.00 ID:d47OCYFA0.net
>>974
ああ、それが現状の最適解な気がするね。
後で汎用関数化したくなっても対応しやすいし。
まあ >>971 みたいな感覚はあるし、関数としてのコストも気になっちゃうけど。

976 :デフォルトの名無しさん (ワッチョイ 551d-1fOb [180.178.89.53]):2023/11/29(水) 23:49:26.08 ID:oO9dmq1+0.net
const num = 1;
とした時、numはCやJavaのint型と違って、1という値のオブジェクトを参照している
という理解でよろしいでしょうか?
(numという名前でラベリングされたメモリ領域には、1そのものではなく
数値オブジェクトへの参照値が入っている?)

977 :デフォルトの名無しさん :2023/11/30(木) 04:02:01.17 ID:uIFlL3tD0.net
>>976
1 はプリミティブ値。
Object型ではない。

978 :973 :2023/11/30(木) 22:41:28.93 ID:l5hD/Y3Y0.net
>>977
レスありがとうございます

分かりました
文字列('Hello World'など)もプリミティブなんですよね
どうやって内部で実装されてるんですか?

979 :デフォルトの名無しさん :2023/11/30(木) 22:57:08.84 ID:mSFTiyup0.net
MDNをまず読みましょう
https://developer.mozilla.org/en-US/docs/Glossary/Primitive

980 :デフォルトの名無しさん :2023/11/30(木) 23:13:04.35 ID:5k4SwxyG0.net
>>976
実装的には全て参照扱いだよ
ただし数値の場合は参照(ポインタ)そのものに数値を埋め込むという方法
だから全て参照だけどメモリは消費しないというハック

981 :デフォルトの名無しさん :2023/12/01(金) 01:54:56.09 ID:Bo4sqMI/0.net
>>978
質問が大雑把過ぎる
もっと具体的に詳しく

982 :975 (ワッチョイ 691d-zrcD [180.178.89.53]):2023/12/02(土) 04:48:25.07 ID:3pMMmiCv0.net
返信くれた方々、ありがとうございます

>>979
TOEICのスコア400点台だったので厳しいです…

>>980
参照扱いでもプリミティブ型って言うんですか?
Javaではintやdoubleなど参照を用いずにデータを記憶する型をプリミティブ型と
呼んでいたので、少し混乱しています…

>>981
すみません、以後気を付けます

983 :デフォルトの名無しさん :2023/12/02(土) 10:49:58.14 ID:qpNh64Np0.net
>>980は気にしなくていいよ
英語苦手でもプリミティブには7つの型がある、ぐらいは読めるだろう
あと日本語のページがないか調べるぐらいはしよう
https://developer.mozilla.org/ja/docs/Glossary/Primitive

984 :デフォルトの名無しさん (ワッチョイ 91ca-j/4L [122.132.80.240]):2023/12/02(土) 11:43:24.98 ID:/unkk9Eq0.net
>>982
そもそもそんなことを気にしてどうするの?
何がしたくての質問?

ぶっちゃけ表向き気にするべきなのは、その変数 a を別の変数 b に代入して、b を操作したら a まで同じように変わるのかどうかだけだと思うよ。

985 :979 (ワッチョイ 691d-zrcD [180.178.89.53]):2023/12/03(日) 12:45:58.94 ID:FUDcVj1n0.net
>>983
分かりました
ありがとうございます

>>984
レスありがとうございます
うーん、まあこだわりとでも言いましょうか…
個人的にはそこまで知っておくことは無駄ではないと思います

986 :デフォルトの名無しさん (ワッチョイ c1b6-egvc [2400:2200:6d6:9e9c:*]):2023/12/03(日) 13:08:07.26 ID:tV1DejKO0.net
>>978の質問なんかは明らかに自分のスキルや理解力に不相応なことを知ろうとしてない?
それを知ろうとするのはもっと力を付けてからがいいと思う

987 :デフォルトの名無しさん (ワッチョイ 1901-+tyV [60.118.124.10]):2023/12/03(日) 14:24:30.66 ID:GsReymgf0.net
>>985
実装を知る以前に仕様は理解してる?
「仕様書のここをどうやって実装しているか、を知りたい」なら誰かしら答えるかもしれないが、そのようなレベルにも見えない
仕様を理解せずして、実装を理解するのは無理

988 :デフォルトの名無しさん :2023/12/03(日) 17:15:18.22 ID:TpyXoIhbM.net
>>987
乗っかって補足すると、同じ仕様の実装なんて何通りもあるのよね。
そこであえて実装を知りたいというなら、その理由も書く方が間違いないよね。

989 :982 :2023/12/04(月) 23:09:24.91 ID:GWbm6wp00.net
レスありがとうございます
遅くなってすいません

>>986
そうですよね
まあ単純に、文字列である以上、変数用に確保したメモリ領域内に簡単には収まらない
だろうなと推測したんです
でも不変な値なら参照使わなくても収まるのかな

>>987
微妙です
入門書を読んで間もないレベルです

>>988
分かりました
まあ実装って言い回しが大仰でした
参照を使ってあるかどうかを特に知りたかったんです

990 :デフォルトの名無しさん :2023/12/04(月) 23:27:59.49 ID:lRGkzbxI0.net
そのレベルを気にする人はもうフレームワーク作るレベルだろう

991 :デフォルトの名無しさん (アウアウウー Sa9d-/D3x [106.146.123.7]):2023/12/05(火) 20:06:09.74 ID:gtr9NjJza.net
>>985
あ、ややこしい書き方してすまん
単にuint64_tが値の参照でオブジェクトの場合はポインタが入ってて
整数の場合はそのまま使ってると言うことを言いたかっただけ
typedef uint64_t JsValue;

JsValueが「値」を指す参照

JsValue obj = createObject(); // Object
JsValue smi = createSmi(); // Small Integer

こうすることでオブジェクトも数値も同じように扱える
V8もJSCも全部これ

992 :982,986 :2023/12/05(火) 23:32:22.63 ID:c1y4Tvg20.net
レスありがとうございます

>>990
そうなんですかね

>>991
内容がハイレベルですね

993 :デフォルトの名無しさん :2023/12/06(水) 00:21:20.37 ID:HaZOzd170.net
>>989
入門書を読んで間もないレベルなら、口が避けても「仕様を理解した」とは言えない
実装を覚えるのは仕様書を読めるようになった後だろう
https://262.ecma-international.org/14.0/

994 :デフォルトの名無しさん :2023/12/09(土) 10:39:43.45 ID:npLWblUF0.net
素人な質問で申し訳有りません。
下記のスクリプトで何故か関数丸々出力されてしまうのです。
テキストでは改行が多すぎる為、投稿出来ないため画像で申し訳有りません。
下のグレーのフォントが出力結果です。
出力指定していないので、何も出力されないはずなのですが…。

https://i.imgur.com/tJnx1oK.jpg

995 :デフォルトの名無しさん :2023/12/09(土) 11:31:37.42 ID:In8GNdRi0.net
>>994
画像でコート見るのはしんどいので、>>2のサイト使って現象が再現するコードを掲示してほしい

996 :デフォルトの名無しさん :2023/12/09(土) 14:27:43.55 ID:iYG1bkmj0.net
>>994
どうでもいいけど関数名の付け方にセンスないな
コメントもつける意味がないゴミ
変換ならconvertとかにすりゃいいのに…

997 :デフォルトの名無しさん :2023/12/09(土) 15:46:37.17 ID:W9usxQKOr.net
/や:が入ってるのを明示してるのはコメントとして意味があるだろう

998 :デフォルトの名無しさん (ワッチョイ 1b56-m+YX [2400:4176:2846:5b00:*]):2023/12/09(土) 16:39:16.69 ID:0uXDsiHr0.net
classのインスタンスで#プライベートメソッドにアクセスする方法ってないんでしょうか?

999 :986 (ワッチョイ b51d-g9yR [180.178.89.53]):2023/12/09(土) 17:13:36.47 ID:YETt4fHv0.net
>>993
はい
リンクありがとうございます

1000 :デフォルトの名無しさん (オッペケ Sre1-tek/ [126.254.232.20]):2023/12/09(土) 17:46:24.03 ID:Mnb70srnr.net
なかったんで次スレ立てた
https://mevius.5ch.net/test/read.cgi/tech/1702111239/

1001 :デフォルトの名無しさん :2023/12/10(日) 11:19:27.25 ID:ngtmyS7f0.net
>>995
サイトの使い方がいまいち分からず試してましたが、サイトでは症状が再現できず想定通りの挙動でした。これは作ってるアプリ側に原因があるのでしょうかね。
mementoというdbアプリだったのですが。

>>996
自覚はあります。プログラムに興味を持ち練習はじめなので勘弁してやってください。思いつかないんですorz

1002 :デフォルトの名無しさん (ワッチョイ 35cb-tek/ [2400:2200:6f2:ada4:*]):2023/12/10(日) 11:47:16.59 ID:v6fUhk/70.net
>>1001
>>994を実行してる環境について書いてくれないと
コードで見えてる部分以外については知りようがないんだから

あと関数名を思いつかないならAIに候補を挙げさせるのはアリ

続きが必要なら次スレにどうぞ

1003 :デフォルトの名無しさん :2023/12/16(土) 00:37:24.71 ID:xiFcB2tC0.net
テスト

1004 :2ch.net投稿限界:Over 1000 Thread
2ch.netからのレス数が1000に到達しました。

総レス数 1004
356 KB
掲示板に戻る 全部 前100 次100 最新50
read.cgi ver 2014.07.20.01.SC 2014/07/20 D ★