JavaScript の質問用スレッド vol.126 (307レス)
1-

1
(2): デフォルトの名無しさん (オッペケ Sr9f-tek/ [126.254.232.20]) [sage] 2023/12/09(土) 17:40:39.92 ID:Mnb70srnr(1/5) AAS
!extend:checked:vvvvvv:1000:512
JavaScript を自ら学ぶ人のための質問スレッドです。
>>2-5のテンプレを読んだ上で質問してください。次スレは>>950>>2
2(3): デフォルトの名無しさん (オッペケ Sre1-tek/ [126.254.232.20]) [sage] 2023/12/09(土) 17:41:59.25 ID:Mnb70srnr(2/5) AAS
■質問テンプレート
【環境】OS, ブラウザをバージョンと共に記入してください。(ex: IE8, Firefox4)
【何をしたのか】何をしたら問題の現象が発生するのか。再現手順を具体的に書いてください。
【エラーメッセージ】エラーメッセージがあれば正確に書き写してください。(Windows なら「コピット」を活用)
【期待する結果】最終的にどういう結果を望んでいるのか、を書いてください。
【サンプルコード】現象を再現可能な最小限のコードを書いてください。
 1レスに収まらないならコード投稿サイトを利用してください。
 外部リンク:plnkr.co 外部リンク:jsbin.com 外部リンク:jsfiddle.net 外部リンク:ideone.com

■次スレの立て方
本文一行目に「!extend:checked:vvvvvv:1000:512」と書いて、>>1-5のテンプレの「前スレ」「関連スレ」を最新化して立ててください。

■JavaScriptスレの現状
元々はWeb制作板が本スレでしたが、ライブラリ信者に荒らされ、プログラム板に避難所として本スレが立てられました。
Web制作板の本スレは荒らされてから次スレが立っておらず、重複スレの消化のみとなっています。
実質的に本スレは存在しない為、質問者はWeb制作板、ブログラム板のどちらのスレで質問しても問題ありません。
の「次スレの立て方」を元に立ててください

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

■前スレ
JavaScript の質問用スレッド vol.125
2chスレ:tech VIPQ2_EXTDAT: checked:vvvvvv:1000:512:: EXT was configured
3
(2): デフォルトの名無しさん (オッペケ Sre1-tek/ [126.254.232.20]) [sage] 2023/12/09(土) 17:43:26.17 ID:Mnb70srnr(3/5) AAS
■関連スレ(Web制作板)
JavaScript の質問用スレッド vol.126 (重複スレの消化)
2chスレ:hp
JavaScript ライブラリ総合質問所 vol.5
2chスレ:hp
jQuery 質問用スレッド vol.7
2chスレ:hp

■各種仕様
◆ECMAScript
外部リンク:bclary.com (ECMAScript 3 HTML版)
外部リンク:www2u.biglobe.ne.jp (ECMAScript 3 和訳)
外部リンク:262.ecma-international.org (ECMAScript 2022)
◆HTML Standard (HTML5)
外部リンク:www.whatwg.org (HTML Living
Standard)
外部リンク:momdo.github.io (HTML Living
Standard日本語訳)
4
(2): デフォルトの名無しさん (オッペケ Sre1-tek/ [126.254.232.20]) [sage] 2023/12/09(土) 17:45:14.13 ID:Mnb70srnr(4/5) AAS
テンプレここまで

内容は前スレ踏襲
5
(2): デフォルトの名無しさん (オッペケ Sre1-tek/ [126.254.232.20]) [sage] 2023/12/09(土) 17:55:10.18 ID:Mnb70srnr(5/5) AAS
テンプレの範囲ぐらい修正しとけばよかったかな
6: デフォルトの名無しさん (ワッチョイ 5510-yLTa [222.230.65.145]) [sage] 2023/12/10(日) 16:33:48.20 ID:ngtmyS7f0(1/6) AAS
前スレで日付変換の関数で質問していた者です。

開発環境としましては、AndroidのmementoというDBを制御するために、Javascriptの使用が可能なので、試しに勉強してみようと思った次第です。

コードエディターや>>2記載のサイトでは正常動作をしていることから、開発環境に問題があると判断しました。ただそうなるとDBと合わせて使用できるメリットが無くなるので代替手段を模索しているところです。

成功例(日時が2つ表示)
画像リンク


失敗例
(consolelogに対応しないため、コメントアウトしていますが、関数が結果に出力される。何も表示されないはず。)
画像リンク


コードエディター
外部リンク[code]:play.google.com

memento
外部リンク:play.google.com
7: デフォルトの名無しさん (ワッチョイ 5510-yLTa [222.230.65.145]) [sage] 2023/12/10(日) 16:34:26.85 ID:ngtmyS7f0(2/6) AAS
const date1 = new Date('2021/01/01')
const date2 = new Date('2022/02/02')
const stDate = dateToYyyymmdd(date1);
const stTime = timeToHhmm(date1);
const edDate = dateToYyyymmdd(date2);
const edTime = timeToHhmm(date2);

console.log(stDate + stTime + " " + edDate + edTime)
8: デフォルトの名無しさん (ワッチョイ 5510-yLTa [222.230.65.145]) [sage] 2023/12/10(日) 16:34:43.88 ID:ngtmyS7f0(3/6) AAS
// DateをYYYY/MM/DD文字列に変換する
function dateToYyyymmdd(date){

let n = date.getFullYear().toString();
n = date.getFullYear().toString() + "/";
n +=
(date.getMonth()+1).toString().padStart(2, "0") + "/";
n +=
date.getDate().toString().padStart(2, "0") + "_";
return(n);
}
9: デフォルトの名無しさん (ワッチョイ 5510-yLTa [222.230.65.145]) [sage] 2023/12/10(日) 16:35:00.00 ID:ngtmyS7f0(4/6) AAS
// DateをHH:MM文字列に変換する
function timeToHhmm(time){
let n = time.getHours().toString().padStart(2, "0") + ":";
n += time.getMinutes().toString().padStart(2, "0");
return(n);
}
10
(2): デフォルトの名無しさん (ワッチョイ 5510-yLTa [222.230.65.145]) [sage] 2023/12/10(日) 16:35:52.81 ID:ngtmyS7f0(5/6) AAS
申し訳有りません。
サービスでの稼働は確認出来たのですが、共有方法が分からないので、連投になってしまいましたが、直接描かせていただきました。
11
(1): デフォルトの名無しさん (アウアウウー Sa49-+EJW [106.155.27.178]) [sage] 2023/12/10(日) 17:01:43.23 ID:013bN9IEa(1) AAS
>>10
よくわからんけどそもそもその環境は関数定義して呼び出すとかできるの?
全体を関数として扱って最後の戻り値を文字列として解釈してるとかそういうノリではなく?
12
(1): デフォルトの名無しさん (ワッチョイ ed27-tek/ [2400:2200:6f2:ad4b:*]) [sage] 2023/12/10(日) 17:01:58.34 ID:uEdCnVbW0(1) AAS
>>10
外部リンク:wiki.mementodatabase.com
>but only the result of the last operation will be entered into the field.
とあるから最後の文の値が結果値として採用される
だからtimeToHhmm関数自体が結果になっている

修正したければコードの最後に
const result = stDate + stTime + " " + edDate + edTime
などと追加すればその値が結果値として採用されるんではないだろうか
13: デフォルトの名無しさん (ワッチョイ 5510-yLTa [222.230.65.145]) [sage] 2023/12/10(日) 21:02:11.63 ID:ngtmyS7f0(6/6) AAS
>>11,12
まさに仰るとおりでございました。
最後に出力文を置くことで正しく稼働を確認できました。
改めて調べようが足らなかったことを痛感しました。正直自分の中に『これ、なんかバグってるのかな…』などと考えてしまってた所もありましたが、単に仕様であったことに恥ずかしさとプラットフォーム開発者に申し訳ないですね。
wikiもしっかり読み込んで改めて勉強しなおしてみます。
本当にありがとうございます。
長々と失礼しました。
14
(1): デフォルトの名無しさん (ワッチョイ b51d-C3j7 [180.178.89.53]) [sage] 2023/12/15(金) 23:44:44.09 ID:WfAwrcm40(1) AAS
nullとundefinedはどう違うのでしょうか?
15
(1): デフォルトの名無しさん (ワッチョイ b701-Y8ba [60.106.64.223]) [sage] 2023/12/16(土) 00:21:53.93 ID:92Act5oB0(1) AAS
>>14
型も値も何もかも違う
16
(1): 14 (ワッチョイ 4f1d-Qk2W [180.178.89.53]) [sage] 2023/12/16(土) 12:33:00.76 ID:3Jo1PIzy0(1/3) AAS
>>15
レスありがとうございます

単純に、nullは「空」、undefinedは「未定義」と理解しておけばいいでしょうか?
うーんでも、空だから未定義であるとも言えるし、未定義だから空とも言える気もします
難しく考え出すとハマりますね…
17
(1): デフォルトの名無しさん (ワッチョイ 5b48-r/Us [2400:2200:3f1:994b:*]) [sage] 2023/12/16(土) 12:50:38.08 ID:GGJUNSgh0(1/2) AAS
まず「空」とはなんぞや、「未定義」とはなんぞやってところから勉強してみたら?
18: 14 (ワッチョイ 4f1d-Qk2W [180.178.89.53]) [sage] 2023/12/16(土) 13:09:24.81 ID:3Jo1PIzy0(2/3) AAS
>>17
レスありがとうございます

自分なりに少し調べてみたら、
undefinedは「これから何かしらの値が入る余地があるがまだ定義されていない」
nullは「値が入りようがないから空」
という違いがあるみたいですね
19
(1): デフォルトの名無しさん (ワッチョイ 5b48-r/Us [2400:2200:3f1:994b:*]) [sage] 2023/12/16(土) 13:43:31.64 ID:GGJUNSgh0(2/2) AAS
意味的には別物だというのは納得できた?
20
(1): 14 (ワッチョイ 4f1d-Qk2W [180.178.89.53]) [sage] 2023/12/16(土) 16:34:04.63 ID:3Jo1PIzy0(3/3) AAS
>>19
はい、それなりに理解出来たと思います
ありがとうございます
JSでは、undefinedに比べるとnullの登場頻度はかなり低いみたいですね
21: デフォルトの名無しさん (ワッチョイ 0e6d-Aq9B [240b:10:8401:ab00:*]) [sage] 2023/12/16(土) 19:13:30.08 ID:UfR4i5aB0(1) AAS
設計ミスだから使い分ける必要はなく
外部とのやりとり以外にnullは使わないと統一した方が問題でにくいし楽
22
(1): デフォルトの名無しさん (ワッチョイ 4f10-n6T6 [180.12.82.129]) [] 2023/12/18(月) 12:29:54.63 ID:UBFKxLGp0(1/4) AAS
配列の宣言はvar list=[];
オブジェクトの宣言var obj={};
配列の配列の宣言は var list=[[]];
ではオブジェクトの配列の宣言はどうすればいいですか?
var obj={[]};のようにしてもできませんでした。
obj["aaa"][0]=100;
obj["bbb"][1]=200;
のように値を入れたいです。
23
(1): デフォルトの名無しさん (ワッチョイ 4f10-n6T6 [180.12.82.129]) [] 2023/12/18(月) 12:38:38.33 ID:UBFKxLGp0(2/4) AAS
配列のオブジェクトって言った方が正しいのかわからないけど
とにかく>>22のように代入したいんです
24
(1): デフォルトの名無しさん (ワッチョイ 0e2a-YOgt [240b:10:8401:ab00:*]) [sage] 2023/12/18(月) 12:58:21.29 ID:kn95Gf6w0(1) AAS
[[]] 配列を入れ子にしても1番目の要素を[]に初期化しているだけで
配列として使いたい場合に必要な手順ではない
仮に1番目を[1,2]、2番目を[3]にしたい時に操作が変わってしまうので邪魔なだけ
配列は空のまま [] で十分

あとconst/letじゃなくvarで書くスタイルは古い
参考にした情報があるなら忘れよう
更新もせずずっと放置しているなら害悪でしかない
25
(1): デフォルトの名無しさん (ワッチョイ 225c-ivtJ [61.196.5.7]) [sage] 2023/12/18(月) 13:13:46.30 ID:BJv/M26K0(1/2) AAS
let obj = {};
obj["aaa"] = [100];
obj["bbb"] = [undefined];
obj["bbb"][1] = [200];
1-
あと 282 レスあります
スレ情報 赤レス抽出 画像レス抽出 歴の未読スレ AAサムネイル

ぬこの手 ぬこTOP 3.664s*