


Comment implémenter la fonction de requête floue dans la liste déroulante dans Angular
Cet article présente principalement l'implémentation par Angular de la fonction de requête floue de liste déroulante, impliquant la réponse aux événements AngularJS et la requête de chaîne et d'autres compétences opérationnelles connexes. Les amis dans le besoin peuvent s'y référer
L'exemple de cet article. décrit l'implémentation de la liste déroulante dans la fonction de requête Angular Fuzzy. Partagez-le avec tout le monde pour référence, les détails sont les suivants :
J'ai étudié Angularjs il y a deux jours, et je dois dire que l'idée mvc d'angularjs est toujours très puissante. Cela reste très avantageux pour les projets axés sur le traitement des données.
J'ai écrit une démo d'une liste déroulante de recherche, j'y ai écrit tous les commentaires, donc ce ne sera plus aussi verbeux.
1. Manière ordinaire de mettre en œuvre
<!DOCTYPE html> <html> <head lang="zh_CN"> <meta charset="utf-8"> <title>www.jb51.net Angular模糊匹配</title> <script src="http://apps.bdimg.com/libs/angular.js/1.4.6/angular.min.js" type="text/javascript"></script> <link href="http://libs.baidu.com/bootstrap/3.0.3/css/bootstrap.min.css" rel="external nofollow" rel="external nofollow" rel="stylesheet"> <script src="http://libs.baidu.com/jquery/2.0.0/jquery.min.js"></script> <script src="http://libs.baidu.com/bootstrap/3.0.3/js/bootstrap.min.js"></script> </head> <body > <p ng-app="myApp" ng-controller="myCtrl"> <input type = 'test' ng-change="changeKeyValue(searchField)" ng-model="searchField" style = 'display:block;width:200px' ng-click = 'hidden=!hidden' value="{{searchField}}"/></input> <p ng-hide="hidden"> <select style = 'width:200px' ng-change="change(x)" ng-model="x" multiple> <option ng-repeat="data in datas" >{{data}}</option> </select> </p> </p> <p> <p><h1>angular输入选择框</h1></p> <p><h2>逻辑实现步骤</h2></p> <p>1文本框做输入,并监控器change事件,在change事件中获取输入值,获取的输入值与选择框中的各个下拉项进行比较</p> <p>2如果包含则只显示包含的部分,不包含则显示全部</p> <p> <script> var app = angular.module('myApp', []); app.controller('myCtrl', function($scope) { $scope.datas = ["key4","xyz","key3","xxxx","key2","value2","key1","value1"]; //下拉框选项 $scope.tempdatas = $scope.datas; //下拉框选项副本 $scope.hidden=true;//选择框是否隐藏 $scope.searchField='';//文本框数据 //将下拉选的数据值赋值给文本框 $scope.change=function(x){ $scope.searchField=x; $scope.hidden=true; } //获取的数据值与下拉选逐个比较,如果包含则放在临时变量副本,并用临时变量副本替换下拉选原先的数值,如果数据为空或找不到,就用初始下拉选项副本替换 $scope.changeKeyValue=function(v){ var newDate=[]; //临时下拉选副本 //如果包含就添加 angular.forEach($scope.datas ,function(data,index,array){ if(data.indexOf(v)>=0){ newDate.unshift(data); } }); //用下拉选副本替换原来的数据 $scope.datas=newDate; //下拉选展示 $scope.hidden=false; //如果不包含或者输入的是空字符串则用初始变量副本做替换 if($scope.datas.length==0 || ''==v){ $scope.datas=$scope.tempdatas; } console.log($scope.datas); } }); </script> </html>
2. >
L'effet final est le suivant :<!DOCTYPE html> <html> <head lang="zh_CN"> <meta charset="utf-8"> <title>www.jb51.net Angular模糊匹配</title> <script src="http://apps.bdimg.com/libs/angular.js/1.4.6/angular.min.js" type="text/javascript"></script> <link href="http://libs.baidu.com/bootstrap/3.0.3/css/bootstrap.min.css" rel="external nofollow" rel="external nofollow" rel="stylesheet"> <script src="http://libs.baidu.com/jquery/2.0.0/jquery.min.js"></script> <script src="http://libs.baidu.com/bootstrap/3.0.3/js/bootstrap.min.js"></script> </head> <body > <p ng-app="myApp" ng-controller="myCtrl"> <p> <select-search datas="datas"></select-search> </p> </p> <p> <p><h1>angular输入选择框 自定义指令方式</h1></p> <p><h2>逻辑实现步骤</h2></p> <p>1文本框做输入,并监控器change事件,在change事件中获取输入值,获取的输入值与选择框中的各个下拉项进行比较</p> <p>2如果包含则只显示包含的部分,不包含则显示全部</p> <p> <script> var app = angular.module('myApp', []); app.controller('myCtrl', function($scope) { $scope.datas = ["key4","xyz","key3","xxxx","key2","value2","key1","value1"]; //下拉框选项 }); app.directive('selectSearch', function($compile) { return { restrict: 'AE', //attribute or element scope: { datas: '=', //bindAttr: '=' }, template: '<input type = "test" ng-change="changeKeyValue(searchField)" ng-model="searchField" style = "display:block;width:200px" '+ 'ng-click = "hidden=!hidden" value="{{searchField}}"/></input>'+ '<p ng-hide="hidden">'+ ' <select style = "width:200px" ng-change="change(x)" ng-model="x" multiple>'+ ' <option ng-repeat="data in datas" >{{data}}</option>'+ ' </select>'+ '</p>', // replace: true, link: function($scope, elem, attr, ctrl) { $scope.tempdatas = $scope.datas; //下拉框选项副本 $scope.hidden=true;//选择框是否隐藏 $scope.searchField='';//文本框数据 //将下拉选的数据值赋值给文本框 $scope.change=function(x){ $scope.searchField=x; $scope.hidden=true; } //获取的数据值与下拉选逐个比较,如果包含则放在临时变量副本,并用临时变量副本替换下拉选原先的数值,如果数据为空或找不到,就用初始下拉选项副本替换 $scope.changeKeyValue=function(v){ var newDate=[]; //临时下拉选副本 //如果包含就添加 angular.forEach($scope.datas ,function(data,index,array){ if(data.indexOf(v)>=0){ newDate.unshift(data); } }); //用下拉选副本替换原来的数据 $scope.datas=newDate; //下拉选展示 $scope.hidden=false; //如果不包含或者输入的是空字符串则用初始变量副本做替换 if($scope.datas.length==0 || ''==v){ $scope.datas=$scope.tempdatas; } console.log($scope.datas); } } }; }); </script> </html>
Notez que l'attribut multiple est défini ici sur la balise select, donc la balise d'entrée peut écraser la balise select sur la page
Si vous n'utilisez pas l'attribut multiple, vous devez utiliser p pour simuler vous-même l'effet de la balise select
Ce qui précède est ce que j'ai compilé pour tout le monde. j'espère que cela sera utile à tout le monde à l'avenir.
Articles connexes :
Comment implémenter l'effet d'animation Taobao réactif à la souris dans jQueryComment utiliser jQuery pour implémenter l'effet d'animation Taobao réactif à la souris Effet d'animation dégradé de transparenceComment juger NaNCe qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Cet article poursuit l'apprentissage d'Angular, vous amène à comprendre les métadonnées et les décorateurs dans Angular, et comprend brièvement leur utilisation. J'espère qu'il sera utile à tout le monde !

Angular.js est une plateforme JavaScript librement accessible pour créer des applications dynamiques. Il vous permet d'exprimer rapidement et clairement divers aspects de votre application en étendant la syntaxe HTML en tant que langage de modèle. Angular.js fournit une gamme d'outils pour vous aider à écrire, mettre à jour et tester votre code. De plus, il offre de nombreuses fonctionnalités telles que le routage et la gestion des formulaires. Ce guide expliquera comment installer Angular sur Ubuntu24. Tout d’abord, vous devez installer Node.js. Node.js est un environnement d'exécution JavaScript basé sur le moteur ChromeV8 qui vous permet d'exécuter du code JavaScript côté serveur. Être à Ub

Cet article vous donnera une compréhension approfondie du gestionnaire d'état NgRx d'Angular et vous présentera comment utiliser NgRx. J'espère qu'il vous sera utile !

Connaissez-vous Angular Universel ? Cela peut aider le site Web à fournir un meilleur support SEO !

Cet article partagera avec vous une expérience pratique d'Angular et apprendra comment développer rapidement un système backend en utilisant Angualr combiné avec ng-zorro. J'espère que cela sera utile à tout le monde !

Avec le développement rapide d'Internet, la technologie de développement front-end s'améliore et se répète constamment. PHP et Angular sont deux technologies largement utilisées dans le développement front-end. PHP est un langage de script côté serveur capable de gérer des tâches telles que le traitement des formulaires, la génération de pages dynamiques et la gestion des autorisations d'accès. Angular est un framework JavaScript qui peut être utilisé pour développer des applications monopage et créer des applications Web composées de composants. Cet article explique comment utiliser PHP et Angular pour le développement front-end et comment les combiner.

Comment utiliser monaco-editor en angulaire ? L'article suivant enregistre l'utilisation de monaco-editor dans angulaire qui a été utilisé dans une entreprise récente. J'espère qu'il sera utile à tout le monde !

Cet article vous présentera les composants indépendants dans Angular, comment créer un composant indépendant dans Angular et comment importer des modules existants dans le composant indépendant. J'espère qu'il vous sera utile !
