元スレ+ JavaScript の質問用スレッド vol.97 +
JavaScript覧 / PC版 /みんなの評価 :
801 = :
>>800
var f = "こんにちはyou、今日も元気ですねyouはとっても元気だyou&you";
f=f+f.replace(/[^(you)]*/g,"").replace(/you/g,"hey");
alert(f);
802 = :
>>801
var f = "こんにちはyou、今日も元気ですねyouはとっても元気だyooooooo&you";
とかでやってみな
803 = :
>>800>>801
こっちもよさそうですね。本当に助かります
804 = :
おまえら有名な質問スレ用コピペ改変に相手するなよ・・・
805 = :
ここまでテンプレ
806 = :
>>802
var f = "こんにちはyou、今日も元気ですねyouはとっても元気だyouoooooo&you";
f=f+f.replace(/[^you]*/g,"").replace(/you/g,"x").replace(/[you]/g,"").replace(/x/g,"hey");
alert(f);
808 = :
生データ配列からコントローラーを介してビューを表示、データ編集後生データ配列内の元の位置に仕舞ったりする処理を考えています。
ただ、今回はランダムなビューに表示し、生データの順番から判断しただけではビューにアクセスできず、
ビューからも自分の情報が生データ配列のどこに格納されていたかは分からない様な条件なのです。
そこでコントローラーに、作ったビューを生データの順通りストックするリストを用意し、
それを介してお互いアクセスし合おうと思うのですが、もっとシンプルな方法がJavaScriptで行えるなら教えてください。
810 = :
>>809
馬鹿正直な処理系だと、例えば
配列[複雑なインデクス計算] = 配列[複雑なインデクス計算] + なんとか
の時にインデクス計算を2回するかもしれないけど、
配列[複雑なインデクス計算] += なんとか
なら1回で済む。
でも、今時の処理系ならどちらも差はない。
811 = :
>>806
おしい
var f = "y_o_u";
だとまちがう。
ここは .*? の最短一致を使うのがいいんじゃないかな。
youが全く現れないケースに気をつけて。
って、正規表現スレむけのネタのような
812 = :
なかなか難しいもんだな
813 = :
>>797で終わってるし
814 = :
>>806
[] の意味理解してる?
[you] は、"y" または "o" または "u" のいずれか一文字に match。
[^you] は、"y" でも "o" でも "u" でもない任意の一文字に match。
どうしても消してから置換したいなら単語単位は諦めて、
f += f.replace(/y(?!ou)|[^y]/g, "").replace(/y/g, "hey");
818 = :
replace2回使う方法が一番負荷少ないのかね
俺の中での優先順位が
負荷軽減>コードの見栄え>コードの長さ
こんな感じだからだろうけど
819 = :
replace の回数より match のさせ方を気にした方が良いよ。
とくに、バックトラックを多発する様なパターンは極端に速度が落ちる。
821 = :
たぶんもう質問したやつは置いてけぼりの状態
822 = :
最初のほうで納得してたみたいだからいいんじゃね?
おれなら正規表現使わずに、indexOfを繰り返して回数数えて、
その回数分足すだけにするけどな。
823 = :
複雑な正規表現って一発じゃ思いつかないからなあ
824 = :
コミュニティから抜粋
////////////////////////////////////////////////////////////////////////////////
336 名前:あげあげ坊主 投稿日:2012/02/24(金) 10:08:32 HOST: FLH1Aj137.hkd.mesh.ad.jp
自動ネット収入システム AUTO-WEBMONEY2の裏技みっけた
スリープモードOFF、自動検索ネットワークON、リトライ復元モードOFF、自動カスタマイズシステムON、
セキュリティモードOFF、サーバートランスモードON、自動構築モードOFFにしてから作動させて、
15分くらい放置したあとに自動構築モードONにすると面白い事になる!
(画像)あっという間に・・www
425 名前:アゲハ蝶 投稿日:2012/02/24(金) 10:45:50 HOST:pl39.nas811.p-wakayama.nttpc.ne.jp
>>336
うぎゃあああああああああああああああああすげえええええええええええええ
あっいう馬に金貯まるんだがwww
477 名前:ネコ 投稿日:2012/02/24(金) 11:35:22 HOST:p8146-ibfp504yamaguchi.yamaguchi.ocn.ne.jp
>>336
ネ申 wwwwww28万www
488 名前:はるき 投稿日:2012/02/24(金) 12:01:35 HOST: KD1140178234.ppp-bb.dion.ne.jp
>>336
キタ━━━(*´・ω・)^ω^)´∀`)´Д`)´ー`)゚∀゚)'A`)゚Д゚)━すげー32マソ━━ !!!
600 名前:425 投稿日:2012/02/24(金) 13:20:02 HOST: pl39.nas811.p-wakayama.nttpc.ne.jp
一時間で56万!!www最高記録か!?w バグ?いいのかこれ?いうなよwww
825 = :
>>823
自分が考えた後、自分より上手い書き方のレス見ると凹む
826 = :
そいや正規表現で思い出したが
compile使うと同じマッチング処理繰り返すより早いって聞いたけど本当?
var f = "こんにちはyou、今日も元気ですねyouはとっても元気だyou&you"
for(1000回){
f.match(/you/g);
}
より
var f = "こんにちはyou、今日も元気ですねyouはとっても元気だyou&you"
re = new RegExp("");
re.compile("you","g");
for(1000回){
f.match(re);
}
の方が早いらしいが
827 = :
実測しろ
828 = :
それ俺前試したけど差が無かった
829 = :
>>826
上は毎回正規表現オブジェクトを生成してる
下は生成されたオブジェクトを再利用してる
まぁでも実際のところchromeでは上の方が早い
var m = 1000000, i, test = "aaaaabbccc",reg = /bb/g,re = new RegExp("");re.compile("bb","g");
i = m;console.time("1");
while(--i) { test.match(/bb/g);};
console.timeEnd("1");
i = m;console.time("2");
while(--i) {test.match(reg);};
console.timeEnd("2");
i = m;console.time("3");
while(--i) {test.match(re);};
console.timeEnd("3");
1: 1571ms
2: 1952ms
3: 1952ms
831 = :
> まぁでも実際のところchromeでは上の方が早い
本末転倒やん
832 = :
>>829
うちだと 3回やって
1: 342ms 1: 348ms 1: 350ms
2: 303ms 2: 304ms 2: 303ms
3: 299ms 3: 309ms 3: 303ms
1を最後に持ってくると
2: 354ms
3: 315ms
1: 322ms
こうなったから、キャッシュが効いてる?
833 = :
差がないというか何回か使うと勝手に最適化されるからな
834 = :
質問。
セレクトボックスで選択中(イベント的にはonfocusしか来てない感じ)に、
カーソルの下にある値に応じて、その値の説明を表示したいと思ってます。
そういう事って可能でしょうか。
835 = :
>>834
onchange
836 = :
>>835
すませんまだ試してないんだけど
onchangeって選択後(マウスを離した確定時)ではなかったでしたっけ
837 = :
>>836
その通り。選択が確定しなければ選択項目を取得できない。
838 = :
>>837
ですよね。
やっぱり選択中は無理ですかねぇ
840 = :
そういうときはselectを自作するもんだ
841 = :
Firefoxでしか動かんな
842 = :
>>840
なるほどその手があったか…めんどくさすぎるorz
でもそれくらいしかなさそうですねw
それ込みで仕様を考えなおしてみます。ありがとうございました。
843 = :
ライブラリが結構あるからそっちを探して改造するほうが早いかもしれんよ
845 = :
最近の流行りで言えばクロージャでprivate化しつつって感じかなー
847 = :
>>845-846
レスありがとうございます
とりあえずは、a1のように定義してf1・f2で共通で扱うような手法はミスというか間違いなんですかね
a1もきちんとa2a3同様、this・selfで扱うべしと
private化など具体的に理解できていないl言葉も多いですが、これから調べてみます
848 = :
>>844
変数 self は不要。
ClassA.prototype.handleEvent にして element.addEventListener("click", this, false); でいい。
849 = :
配列がありまして
array[0] ="hoge123";
array[1] ="fu123";
array[2] ="fugefuge123";
をarray.joint()でつなげるとき全部の最後についた123の部分を取り除きたいのですが
forを使って全部毎回slice(0,-3)って取り除くしかないのでしょうか?
850 = :
map
類似してるかもしれないスレッド
- + JavaScript の質問用スレッド vol.95 + (1001) - [97%] - 2012/1/17 4:16
- + JavaScript の質問用スレッド vol.87 + (1001) - [97%] - 2011/6/21 6:33
- + JavaScript の質問用スレッド vol.99 + (1001) - [97%] - 2012/5/7 4:32
- + JavaScript の質問用スレッド vol.98 + (1001) - [97%] - 2012/4/9 14:46
- + JavaScript の質問用スレッド vol.96 + (1001) - [97%] - 2012/1/28 23:01
- + JavaScript の質問用スレッド vol.94 + (1001) - [97%] - 2012/1/8 15:46
- + JavaScript の質問用スレッド vol.93 + (1001) - [97%] - 2012/1/1 4:46
- + JavaScript の質問用スレッド vol.93 + (1001) - [97%] - 2011/12/10 18:31
- + JavaScript の質問用スレッド vol.90 + (1001) - [97%] - 2011/11/15 20:32
- + JavaScript の質問用スレッド vol.90 + (1001) - [97%] - 2011/10/26 4:18
- + JavaScript の質問用スレッド vol.77 + (1001) - [97%] - 2010/5/8 19:06
- + JavaScript の質問用スレッド vol.137 + (1003) - [95%] - 2019/3/26 11:46
- + JavaScript の質問用スレッド vol.127 + (160) - [95%] - 2021/7/16 9:30
- + JavaScript の質問用スレッド vol.127 + (1001) - [95%] - 2016/2/4 0:15
- + JavaScript の質問用スレッド vol.117 + (1009) - [95%] - 2014/8/5 3:30
- + JavaScript の質問用スレッド vol.107 + (1001) - [95%] - 2013/9/7 10:16
- + JavaScript の質問用スレッド vol.82 + (1001) - [95%] - 2011/1/19 7:54
トップメニューへ / →のくす牧場書庫について