TypeScript part2 [転載禁止]©2ch.net

レス数が1000を超えています。これ以上書き込みはできません。
1デフォルトの名無しさん2015/04/30(木) 18:37:29.98ID:ynMflk1l
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/

952デフォルトの名無しさん2018/01/17(水) 16:20:55.33ID:AWcujNq7
手動で保存・復元すればOK

953デフォルトの名無しさん2018/01/17(水) 16:23:04.93ID:AWcujNq7
まぁ、classレベルならいいけど、interfaceレベルだときついかもしれんが。

954デフォルトの名無しさん2018/01/18(木) 18:36:14.16ID:c8bYFLwE
Announcing TypeScript 2.7 RC
https://blogs.msdn.microsoft.com/typescript/2018/01/17/announcing-typescript-2-7-rc/

毎回RC版出してるけど、VSCodeやTSって更新早いからいらないと思う

955デフォルトの名無しさん2018/01/24(水) 05:53:19.16ID:V1qhcEkf
localStorageとかreduxとか使ってると意図せず型変換が入ってtscはDate型の想定なのに実際はstringという状況マジ勘弁してください。

956デフォルトの名無しさん2018/01/24(水) 08:16:36.90ID:BFkGLEDk
>tscはDate型の想定なのに実際はstringという状況

そりゃ不適切な型付けしてしまっただけじゃね?
stringを入る可能性があるanyをDateと決め打ちしたとか。

957デフォルトの名無しさん2018/01/25(木) 22:12:47.33ID:cFDHLCLJ
DateがJSON serializableじゃないって話でTypeScriptの問題でもない

958デフォルトの名無しさん2018/01/29(月) 11:43:46.31ID:16WZc9vb
インスタンスではなくclass を引数に取った関数を作りたいんですが、良い方法がないでしょうか?
redux.connectをラップする関数を作りたくて上記手段を求めています
サンプルコードはいかにおいています
https://goo.gl/FF5jFc

959デフォルトの名無しさん2018/01/29(月) 11:48:46.22ID:16WZc9vb
>>958
すんません。自己解決
interface IBase {
new (message: string): Base;
}

960デフォルトの名無しさん2018/01/29(月) 14:06:48.67ID:16WZc9vb
返り値とか省略すると推論してくれますけど推論の結果を取得する方法ってないですかね?
vscodeでカーソルを合わせてると出るんですけどカーソル合わせている間しか出ないのでコピペしづらくて。

961デフォルトの名無しさん2018/01/29(月) 16:26:17.34ID:g7co9PB2
>>959
Baseって何を指すの?

962デフォルトの名無しさん2018/01/31(水) 10:23:18.30ID:V9tZNzCA
TypeScriptでglobal import的なものってないですかね?
ロガーを作ったんですけど、それを毎回importするのがしんどくて

963デフォルトの名無しさん2018/02/01(木) 14:40:42.51ID:ma2l7eSX

964デフォルトの名無しさん2018/02/05(月) 22:05:36.77ID:wQgqkVj5

965デフォルトの名無しさん2018/02/05(月) 23:37:11.09ID:Rv6TwvHy
Conditional types関連は既にmergedなのか

966デフォルトの名無しさん2018/02/06(火) 05:58:37.68ID:vXstL54C
小躍りしながら使ってみたところ速攻でバグにぶち当たって無事死亡
修正されるまで一回休み

967デフォルトの名無しさん2018/02/13(火) 05:54:42.41ID:kAM/OKSF
型を後付した言語の限界があるよな。
ストレージに一度保存して意図せずjsonになってたり、関数のインターフェース上nullやundefind許容しない設定にしてても結局js側でnullの可能性のある値を渡されたらバグるし。

例えばjsとtsの境界部分。
モジュールとして外出ししている関数とかのインターフェースとかをきちんとnullチェックしてくれるコードを自動で埋め込んでくんないかな。

968デフォルトの名無しさん2018/02/13(火) 06:47:09.07ID:a2BGtfue
それは信頼できないjsが悪いだけだろ
外部のクソコードはどうにもならん

969デフォルトの名無しさん2018/02/13(火) 09:13:05.77ID:cOH/iFjL
TypeScriptが目指してるのはコンパイル時型チェックであって実行時型チェックではない
コンパイル時型チェックならパフォーマンスに影響はない(処理系によってはむしろ向上する)が実行時型チェックは明確にパフォーマンスが落ちる

PHPなんかは実行時型チェックを実装しちゃったもんだからクラスのメンバに型宣言するRFCすらリジェクトされてる

970デフォルトの名無しさん2018/02/13(火) 15:21:25.94ID:xpZzv5qK
>>969
ですよね。それはわかっているんですが、、、、
せめてlint的な感じでjs向けのインターフェースが null| undefinedの可能性があるから直せみたいな警告が出るといいんですけど。
async func 内の await記入漏れと一緒にほしい。

971デフォルトの名無しさん2018/02/13(火) 15:22:21.77ID:xpZzv5qK
http://blog.yux3.net/entry/2017/06/08/202859
あと objectとObjectがあるって知らなかった。
hyperappの型定義で始めて見た。

972デフォルトの名無しさん2018/02/13(火) 22:00:08.76ID:XkJQyT0D
jsから呼ばれる部分はどうやってもチェックしようがないと思うぞ。

973デフォルトの名無しさん2018/02/20(火) 18:34:14.34ID:KguAhC0Q
yarnのワークスペースを使用して、Create React AppとCreate React Native App (Expo) で共通のコードを共有する
https://taiyaq.com/contents/gk1Kr17x8vW9LIozNo51lez9rr
を参考にしてcreate-react-app でtypescriptプロジェクトを作ったんだけど
ワークスペース内での型情報の共有がうまくいかない。
それぞれ単体では動くんだけど。既に試している人っている?

974デフォルトの名無しさん2018/02/26(月) 16:47:13.03ID:Y4Glcgpd
ブラウザで動く個人的なちょっとしたものしか作らなくて、
ライブラリはimportしないで自分でscriptタグで読み込んでるから、
@typesの定義だけ欲しいんだけど、今って中身のないstubばかりで
importしないと使えないんだけど、これってどうすればいいのでしょうか?

仕方なくファイルをルートにコピーして、意味がわからないまま
export as namespace hogehoge; みたいな文をくっつけたりして
何とか機能するようにしてるけど、非常に困ってます

975デフォルトの名無しさん2018/02/26(月) 17:28:19.81ID:wXoocKSL
.d.tsファイルでインポートすればいいはず

976デフォルトの名無しさん2018/02/26(月) 19:51:46.67ID:Y4Glcgpd
いろいろやってみたけど、なかなか上手くいかない。
tsc --listFilesってやると、定義自体は読み込めてるようなんだけど、
要するに、d.tsファイルがIsomorphic modules (UMD global)ってやつに対応した書き方になってなくて、
それに対応するためにexport as namespace hogehoge; が必要だったりするらしい
https://www.typescriptlang.org/docs/handbook/modules.html#umd-modules

977デフォルトの名無しさん2018/02/26(月) 21:54:01.34ID:0Cvn/PR2
>>974
ちょっと言ってることがわからないからこういうときは小さいサンプルでも作ってどっかにあげてみてくんない?
そしてそうやって小さくまとめてみると意外と自己解決したりするもんだ。

978デフォルトの名無しさん2018/02/26(月) 23:16:55.53ID:Y4Glcgpd
例えばmomentを使う場合、scriptタグでmoment.jsを読み込んでいれば、
自分のjsではconsole.log(moment().format("YYYYMMDD hh:mm:ss"))みたいに使えます。
そのjsをtypescriptで書こうとした場合、moment()の定義が必要になります。
そこで@types/momentをインストールするわけですが、@typesはオワコンらしく、
実際にはmoment自体のパッケージもインストールされて、その中の定義ファイルが
参照されるようになります。
しかし、自分が使おうとしているmoment()は、トップレベルのwindow.moment()なわけですが、
定義ファイルでは、そのことが考慮されていないために定義を見つけられないようです。
(エラーは出ますが、anyとしてコンパイルはされます。)
その定義を見つけらるようにするおまじないが、export as namespace moment;のようです。

結局は、モジュールシステムに合わせた定義ファイルの書き方を
理解している人が少ないのだと思います。
export hogehoge とか export default hogehoge とか export = hogehogeとか
わけわかりません。

979デフォルトの名無しさん2018/02/27(火) 01:53:35.35ID:ZLoGDkNB
>>978
@typesは別にオワコンじゃない。
型定義を提供するのに2つのルートがあるってだけ。
momentは作者側で型定義を提供してくれてるってだけ。

ところで解決したってことでいいんだよね?
/// <reference path="./mytypes/moment.d.ts"/>
みたいな感じでカスタムしたd.tsを読めばいいだけだし。

980デフォルトの名無しさん2018/02/27(火) 01:59:51.55ID:ZLoGDkNB
つーかUMD対応中みたいだね
https://github.com/moment/moment/pull/3688

ワークアラウンドとして

import * as _moment from 'moment';
export as namespace moment;
export = _moment;

というd.tsを作ってimportすればいい

981デフォルトの名無しさん2018/02/27(火) 12:44:23.84ID:XDcEi9Sw
import使っちゃった意味ないんだけどね
vueみたいに複数のファイルに分けられちゃうと大幅に変えないといけないから
気軽にプルリクできない感じがする
だが自分でその場しのぎの対応してると、バージョン上げられた時に詰む

982デフォルトの名無しさん2018/02/27(火) 12:53:20.87ID:XDcEi9Sw
勘違いしてた
import _moment from 'moment';
export as namespace moment;
export = _moment;
とか、
import _Vue from 'Vue';
export as namespace Vue;
export = _Vue;
みたいに書けばいいのか。
すごい。解決した

983デフォルトの名無しさん2018/03/01(木) 22:44:29.35ID:V7eofqS1
次スレカモン

984デフォルトの名無しさん2018/03/12(月) 23:33:32.22ID:ZJVFDbUv
TSConf 2018
https://tsconf.io/

初のカンファか

985デフォルトの名無しさん2018/03/16(金) 08:23:22.72ID:K5Isy9NI

986デフォルトの名無しさん2018/03/16(金) 14:11:16.40ID:HcB/quXY
>>983
次スレのテンプレに入れたほうがいいものとかある?

987デフォルトの名無しさん2018/03/17(土) 00:42:53.78ID:4Xu/HAYS
tsconfigのexcludeの項目を、compilerOptionsの中に書いてて、何でダメなんだろう悩んじゃった
設定はcompilerOptionsの中に書くものと思い込んでて、全然気付けなかった

988デフォルトの名無しさん2018/03/17(土) 21:01:59.42ID:zUTKt+H5
>>986
リポジトリとかWikiとかWhat'sNewあたり?
あとは流れで

989デフォルトの名無しさん2018/03/28(水) 08:14:57.22ID:3iq+90ex

990デフォルトの名無しさん2018/04/02(月) 17:52:32.10ID:G4IZotVZ
俺のtypescriptが好きすぎる感情をどこにぶつけていいかわからない

991デフォルトの名無しさん2018/04/02(月) 18:53:21.97ID:aSG3UjFJ
Qiitaでええやろ

992デフォルトの名無しさん2018/04/03(火) 10:37:57.34ID:0rmSrban
>>990
俺も俺も!。qiitaでもいいしココでもいいよ!!

993デフォルトの名無しさん2018/04/03(火) 11:33:16.29ID:R6gDm2yr
次スレよろ

994デフォルトの名無しさん2018/04/05(木) 19:58:55.32ID:0c0qrJs0
スレ立てにぶつけることが決まったな

995デフォルトの名無しさん2018/04/20(金) 07:03:30.59ID:yIya3QmH
どうしたん?人気あるわりにここ静かやん

996デフォルトの名無しさん2018/04/20(金) 09:50:01.67ID:WJk0jxxj
続きはCMのあとで!

997デフォルトの名無しさん2018/04/24(火) 20:06:57.83ID:TUZ43qB9
はよ次スレ

998デフォルトの名無しさん2018/04/24(火) 21:50:54.24ID:BAt1Eldp
うむ

999デフォルトの名無しさん2018/04/26(木) 21:48:57.62ID:mMDBzDaB

1000デフォルトの名無しさん2018/04/26(木) 21:52:07.15ID:vM7mL5EC
safariが次のIEと呼ばれているように、
Typescriptは次のcoffeescriptと言われているwww

10011001Over 1000Thread
このスレッドは1000を超えました。
新しいスレッドを立ててください。
life time: 1092日 3時間 14分 38秒

10021002Over 1000Thread
5ちゃんねるの運営はプレミアム会員の皆さまに支えられています。
運営にご協力お願いいたします。


───────────────────
《プレミアム会員の主な特典》
★ 5ちゃんねる専用ブラウザからの広告除去
★ 5ちゃんねるの過去ログを取得
★ 書き込み規制の緩和
───────────────────

会員登録には個人情報は一切必要ありません。
月300円から匿名でご購入いただけます。

▼ プレミアム会員登録はこちら ▼
https://premium.5ch.net/

▼ 浪人ログインはこちら ▼
https://login.5ch.net/login.php

レス数が1000を超えています。これ以上書き込みはできません。