2017-01-14 19 views
1

私は立ち往生しており、私はここで間違っているのか分かりません。だから、これは私が使用していますHTMLです:入力フィールドをクリックでクリアできません

<ion-searchbar class="searchBar"> 
    <label> 
    <input class="searchField" type="search" placeholder="Search" ng-model="findAndSearch" /> 
    <a class="clear" ng-click="findAndSearch = '' ">X</a> 
    <i class="icon ion-search placeholder-icon"></i> 
    </label> 
</ion-searchbar> 

をそして、私は私の入力フィールドに何かを入力/入力したとき、これはHTML 出力されます。

<ion-searchbar class="searchBar"> 
    <label> 
    <input class="searchField ng-valid ng-not-empty ng-dirty ng-valid-parse ng-touched" type="search" placeholder="Search" ng-model="findAndSearch" /> 
    <a class="clear" ng-click="findAndSearch = '' ">X</a> 
    <i class="icon ion-search placeholder-icon"></i> 
    </label> 
</ion-searchbar> 

だから、これは何と言っていますか?空ではなく、空(空でない)のときは、自動的にクラス名ng-not-emptyng-not-emptyが置かれます。

私が作ったボタンをクリックするたびに、何もしません。私はコンソールにエラーはありませんが、私が言ったように:私は自分の入力フィールドに何かを書くたびに、私はそれをリセットすることはできません/このボタンで削除します。

私が間違っていることや何が間違っている可能性がありますか?

PS:私はすでにthis SO postのすべての解決策を試しました。

+0

コントローラにfindAndSearch変数を消去するメソッドを作成しようとしましたか? –

+0

はい、私がしたことは何でも、空のクラス名を取り除くことはできません – Siyah

答えて

1

わかりましたので、私はこの問題を修正していると私はまだ、なぜか、それを引き起こしているものを知っているが、修正はありませんこのようなものです:あなたが見ることができるように

<ion-searchbar class="searchBar"> 
     <label> 
     <input class="searchField" type="search" placeholder="Search" ng-model="findAndSearch" /> 
     <i class="icon ion-search placeholder-icon"></i> 
     </label> 
     <a class="clear" ng-click="findAndSearch = '' ">X</a> 

    </ion-searchbar> 

、私はアンカーを入れているng-clicklabel要素の外にあり、今は突然動作します。信じられない。

助けてくれてありがとう!

0

私はあなたのコードでjsfiddleにスニペットを作成して、すべてが正常に動作: ngModelがクリアされ、あなたがX上でクリックしたときに削除クラスNG- - 空ではないが、だから、コードのこの部分では問題ないように見えます

<div ng-app="app"> 
<ion-searchbar class="searchBar"> 
    <label> 
    <input class="searchField" type="search" placeholder="Search" ng-model="findAndSearch" /> 
    <a class="clear" ng-click="findAndSearch = '' ">X</a> 
    <i class="icon ion-search placeholder-icon"></i> 
    </label> 
</ion-searchbar> 
</div> 
+0

ええ、ありがとう...私は実際に同じ問題を抱えています。 – Siyah

+0

@Siyahエラーの原因となるものを理解しようとすると、コードを取り除くことしか示唆できませんでした – maksimr

+0

助けてくれてありがとう、私はそれを感謝します – Siyah

1

私はAngular Documentationから何かを得ました。

ボタンに変わっていますが、これは問題ではないと思います。

はこれをチェックしてください:Clear Model

を次の例では、モデルの変更をデバウンスする方法を示しています。モデルは最後に変更されてからわずか1秒後に更新される になります。 Clearボタンを押すと、 のデバウンスされたアクションはキャンセルされ、値は空になります。デバウンスが、あなたのフォーム内の特定のフィールドに$ rollbackViewValue()

<div ng-controller="ExampleController"> 
    <form name="userForm"> 
    Name: 
    <input type="text" name="userName" 
      ng-model="user.name" 
      ng-model-options="{ debounce: 1000 }" /> 
    <button ng-click="userForm.userName.$rollbackViewValue(); user.name=''">Clear</button><br /> 
    </form> 
    <pre>user.name = <span ng-bind="user.name"></span></pre> 
</div> 

ありません。 and user.name = ''の後

ご連絡ください。あなたのコードで

<a class="clear" ng-click="findAndSearch = '' ">X</a> 

あなたが試してみてください。

<a class="clear" ng-click="yourForm.(give some ID to your input).$rollbackViewValue(); findAndSearch = ''">X</a> 
+0

私のスニペットで例を挙げてもらえますか?あなたは私が持っていない多くのものを見るので、あなたが正確に何を意味するのですか?私は必要がありません... – Siyah

+0

ng-click = "userForm.userName。$ rollbackViewValue();あなたのタグにuser.name = '' "... –

+0

ありがとうElek、まだこれは動作していません何も起こりません – Siyah

関連する問題