質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.37%
TypeScript

TypeScriptは、マイクロソフトによって開発された フリーでオープンソースのプログラミング言語です。 TypeScriptは、JavaScriptの構文の拡張であるので、既存の JavaScriptのコードにわずかな修正を加えれば動作します。

Q&A

1回答

12985閲覧

Angular2でのフォーカス設定について

nekoneko96

総合スコア8

TypeScript

TypeScriptは、マイクロソフトによって開発された フリーでオープンソースのプログラミング言語です。 TypeScriptは、JavaScriptの構文の拡張であるので、既存の JavaScriptのコードにわずかな修正を加えれば動作します。

0グッド

0クリップ

投稿2016/11/04 04:59

編集2016/11/04 06:17

###前提・実現したいこと
Angular2において、特定の項目にフォーカスを設定したい。
具体的には「編集開始」ボタンをクリックするとテキストボックスが表示され、そこにフォーカスをあてたい。

###該当のソースコード
component.html

<div *ngIf="isEditing"> <input type="text" id="txtEditor" placeholder="入力してください" /> </div> <div *ngIf="!isEditing" (click)="beginEdit()"> 編集開始 </div>

component.ts

beginEdit(event: any) :void { this.isEditing= true; ★ここに「txtEditor」コントロールにフォーカスをセットするコードを記述? }

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

<div *ngIf="isEditing"> <input type="text" id="txtEditor" #txtEditor placeholder="入力してください" /> </div> <div *ngIf="!isEditing" (click)="txtEditor.focus()"> 編集開始 </div>

たぶんこれだけでいけます。

投稿2016/11/04 06:07

timy

総合スコア168

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

nekoneko96

2016/11/04 06:22

ご回答誠にありがとうございます。 試してみましたが、フォーカスがセットされませんでした。 また「編集開始」をクリックした際「isEditing」のフラグを変更しテキストエディターを表示させたいと思っております。 そのため、下記の2点を網羅できる方法があれば大変助かります。 ・beginEdit()関数を実行し「isEditing」フラグを変更する ・txtEditorにフォーカスを設定する。
timy

2016/11/04 06:39

input要素にも #txtEditor を追加してあるんですが適用しました? わかりづらくてすみません。 なるべくフォームのことはテンプレート側で完結させたほうがハマりにくくていいと思うんですが、 <div *ngIf="!isEditing" (click)="beginEdit(txtEditor )"> とした上で beginEdit(txtEditor: any) :void { this.isEditing= true; txtEditor.focus(); } もっといいやり方があるかもしれませんが、手元で試してみた感じ動いてはいます。
nekoneko96

2016/11/04 09:36

追記誠にありがとうございます。 ご教授頂いた方法で再度確認してみました。 結果としてはtxtEditorがngIfの内部にあり、「isEditing」のフラグが立つまで描画されないため、 (click)="beginEdit(txtEditor)"で引数で渡しているtxtEditorがundefinedとなってしまいます。 ※txtEditorをngIfの外に出して常に描画される形にすると正常にフォーカスがセットされます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.37%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問