TypeScript part2 [転載禁止]©2ch.net
レス数が950を超えています。1000を超えると書き込みができなくなります。
http://www.typescriptlang.org/
TypeScript lets you write JavaScript the way you really want to.
TypeScript is a typed superset of JavaScript that compiles to plain JavaScript.
Any browser. Any host. Any OS. Open Source.
前スレ
http://peace.2ch.net/test/read.cgi/tech/1349187527/ immutable.js v4まだちゃんと動かんのね。補完効くなら早く使いたい。 flowは静的解析ツールでtypescriptが言語ってことでいいの? 今はTSとほぼ同じ構文が使えるみたいだし推論が強い分言語としてはFlowのほうが格上になったと思うよ
開発ツール等を含めた評価はどうなるか知らんが >>878
対応するライブラリが圧倒的に少ないからflowはゴミだよ
TSと完全互換とかならまだ可能性あったかもね 最初は俺もゴミかと思ったけど静的解析ツールとしてってことだと
jsのプロジェクトに段階的に型をつけていくならありかなって思ったんだよね。 >>880
TSだって段階的に型を付けられるっしょ。 非英語Issueが次々と投げ込まれていくところを想像すると胸が熱くなるな
誰がこういうの決定してんだろ コマンドラインメッセージが日本語化されるの?いらんだろそれ ローカライズありがたいけどところどころ明らかな誤訳が混じってる 誤訳を見つけてくれてありがとう
お前のプルリクを待ってるぜ! コマンドラインよりhandbookの方を翻訳してほしいよね 2.4.2から2.5.3に上げたら、User defined type-guard functionとTagged union typeの組み合わせで
型をうまく判断してくれなくなった。バグか仕様変更かどっちだろう? TypescriptでReact使ってる人にお聞きしたいんですけど
Componentを継承して新しいコンポーネントを作るわけですけど、
class CurrentComponet extends React.Component<Props> {
}
とつくってさらに
class NewComponet extends CurrentComponet {
}
とやってNewComponetをつくるとしますよね。
それはそれで使えるんですけどNewComponetのpropsはCurrentComponetのpropsしか使えないですよね。
PropsをNewComponet用に拡張する方法ってないですかね?
素直に一からComponent作るしかないでしょうか >>892
class CurrentComponet<T extends Props> extends React.Component<T> {
} >>893
うほー。神よ!
でもぶっちゃけ何が起こってるのかよくわかってないです。
> class CurrentComponet<T extends Props> extends React.Component<T> {
上記Tは一体いつ解決されてるんですかね。
そもそもTypeScriptでReactのコンポーネントの書き方ってこっちが正解だったりするんで? それか
class CurrentComponet<T> extends React.Component<T&Props> {
}
でもいいな
こっちが使う側からすると楽かも
>>894
説明面倒だからggrks >>895
単純にReact.d.tsと見比べてみると良い。結局使う時に<Props>を使えるようにCurrentComponet<T> としておくのが目的
ジェネリクス型に追加情報を与えるための概念と考えると分かりやすい。
<T>をTopに残しておいてそこを解決すると React.Component<T>も自動的に追従する >>870
いろいろあるけどちゃんと探した?
今さら誰かに再発明してもらって↓とかに勝てるの?
https://codesandbox.io >>899
おっ。そこは知ってたけどTypeScriptのコード補完効くとしらなかったわ。ありがと 地味にawait書き忘れてちゃんと動かないというパターンが多発してるんですが
TSLintでawait入れ漏れで指摘する機能ってないですかね? >>901
c#だと書き忘れた場合はコンパイラが警告出してくれるんだけどね なお間に合わなかったバグフィクスはガンガン後回しにしてリリースする模様 >>906
アンギュラーってぶっちゃけ使ってる人いるの? Google自身が使ってないのにどうして使うというのか 2.6になったらコンパイルエラーが多発する。react-redux のconnect周りで。
なんでー MEAN勉強中なのにangulerってマイナーなの?ショック コンストラクタを複数定義できないのでしょうか??
うーん。 オーバーロードはできるけど、実装は1つとか・・
JSONへのシリアライズ・デシリアライズは自分で制御するので、
constructor(json: any)と
construcotr(parameter1: type1, parameter2: type2)
二つ用意したいんですけど。最初は
construcotr(parameter1: type1, parameter2: type2)だけ用意しえ、
staticメソッドの方に
statis parseJson(json: any): Class1として、そこでconstrucotr(parameter1: type1, parameter2: type2)を呼んでたんですけど、
これだと子に親のインスタンスの参照渡せないんですよね。 ごめんなさい。これじゃ何いってるからんし、意味不明ですね。 願望なんだけど
Typescriptは言語自体がWebアプリ開発用に
丸ごとフレームワークになったら良いと思う。
Flash(flex)のActionscript3も
フレームワーク化達成した様だし。
http://flex.apache.org/ >>920
JSのスーパーセット目指してるんだし無理に決まってんだろ >>920
TypeScriptでkoa.js使えばいいんでわ?
なんか違うの? >>923
すみませんkoa.jsの存在を知りませんでした。
良さげなので検討してみます。 人気沸騰中のはずなのに年々参加者が減っていきついにアドカレ作られすらしなくなったTypeScriptさん TypeScript関係ないけど、アドカレVue.jsすげぇな。React人気ないのか?? ES6普及したから
AltJSへの興味が薄れてるんじゃね? まだasync await周りが完成してないけどね。
とりあえずmapとかfilterが普通に使えるようになってほしい stackblitzいいな。マジでplayground系の決定版感ある。
https://stackblitz.com/edit/react-ts typeScriptのinterfaceで配列の要素数を制約する方法ってありますかね? >>932
何に使うの?
空でない配列なら分かるけど もしかして:タプル機能を知らない
let vec:[number,number=[1,1]; ミス
let vec:[number,number]=[1,1];
もちろんこれでもOK
type Vec=[number,number];
let vec:Vec=[number,number]; 前にもタプルあるのにタプル欲しい言ってたやついたような https://www.typescriptlang.org/docs/handbook/advanced-types.html
タプルもだけど、このページ読んでない人多くね?
TypeScript語るなら&、|、is、keyofくらいマスターしておけよな >>937
すっかり忘れとりました。Enumとかも使ってなかった。
>>940
ですよね。
>>933
online vscode と名乗ってる (´・ω・`) デコレータがなんの役に立つのかわからん… 一時期使ってみたが全部取っ払って今は一切使ってない
デコレータを使う設計自体が悪い
技術的負債になるワークアラウンドが不運にも市民権を得てしまったのがデコレータ
デコレータを使うのは未熟者の証 使ってないけど、デコレータはDI(dependency injection)(依存性の注入)に使うんでしょ?
そもそもそれが必要な事なのか知らんけど DIはコンストラクタ注入だけでいい
メソッドだの継承だのデコレータだの無駄に複雑なだけ interfaceを使ってるとjsonでセーブする時にすごく便利なんだけどメソッドが生やせないのが辛い。
なんとかならないかな まぁ、classレベルならいいけど、interfaceレベルだときついかもしれんが。 localStorageとかreduxとか使ってると意図せず型変換が入ってtscはDate型の想定なのに実際はstringという状況マジ勘弁してください。 >tscはDate型の想定なのに実際はstringという状況
そりゃ不適切な型付けしてしまっただけじゃね?
stringを入る可能性があるanyをDateと決め打ちしたとか。 DateがJSON serializableじゃないって話でTypeScriptの問題でもない インスタンスではなくclass を引数に取った関数を作りたいんですが、良い方法がないでしょうか?
redux.connectをラップする関数を作りたくて上記手段を求めています
サンプルコードはいかにおいています
https://goo.gl/FF5jFc >>958
すんません。自己解決
interface IBase {
new (message: string): Base;
} 返り値とか省略すると推論してくれますけど推論の結果を取得する方法ってないですかね?
vscodeでカーソルを合わせてると出るんですけどカーソル合わせている間しか出ないのでコピペしづらくて。 TypeScriptでglobal import的なものってないですかね?
ロガーを作ったんですけど、それを毎回importするのがしんどくて Conditional types関連は既にmergedなのか 小躍りしながら使ってみたところ速攻でバグにぶち当たって無事死亡
修正されるまで一回休み 型を後付した言語の限界があるよな。
ストレージに一度保存して意図せずjsonになってたり、関数のインターフェース上nullやundefind許容しない設定にしてても結局js側でnullの可能性のある値を渡されたらバグるし。
例えばjsとtsの境界部分。
モジュールとして外出ししている関数とかのインターフェースとかをきちんとnullチェックしてくれるコードを自動で埋め込んでくんないかな。 それは信頼できないjsが悪いだけだろ
外部のクソコードはどうにもならん TypeScriptが目指してるのはコンパイル時型チェックであって実行時型チェックではない
コンパイル時型チェックならパフォーマンスに影響はない(処理系によってはむしろ向上する)が実行時型チェックは明確にパフォーマンスが落ちる
PHPなんかは実行時型チェックを実装しちゃったもんだからクラスのメンバに型宣言するRFCすらリジェクトされてる >>969
ですよね。それはわかっているんですが、、、、
せめてlint的な感じでjs向けのインターフェースが null| undefinedの可能性があるから直せみたいな警告が出るといいんですけど。
async func 内の await記入漏れと一緒にほしい。 http://blog.yux3.net/entry/2017/06/08/202859
あと objectとObjectがあるって知らなかった。
hyperappの型定義で始めて見た。 レス数が950を超えています。1000を超えると書き込みができなくなります。