Angularjs material 实现搜索框功能_AngularJS

angular-material 是 AngularJS 的一个子项目,用来提供实现了 Material Design 风格的组件。

Material 提供了大量的android 风格的UI组件,使用 angularjs + Material 可以很容易开发出风格接近原生 Android 5.x 的web界面。但在实际使用的过程中并不总是能满足我们的需求。开发一个组件就成了我们必须学习的内容。

下面是一个组件的实现:

//前面省略若干代码
directive('mdSearchInput',[function(){
return{
restrict:'E',
controller:['$scope','$timeout',function($scope,$timeout){
var tsk=null;
$scope.delay=1000;
$scope.on_changed=function(){
if(null !== tsk) {$timeout.cancel(tsk);} //去掉前一个任务
tsk = $timeout(function(){
$timeout.cancel(tsk);tsk=null;
$scope.onSearch()($scope.searchText);
},$scope.delay);
};$scope.on_clear=function(){
var tsk=null;$scope.searchText='';
tsk=$timeout(function(){
$timeout.cancel(tsk);tsk=null;
$scope.onSearch()($scope.searchText);
},100);
}
}],
scope:{
inputName: '@mdInputName',
searchText: '=?mdSearchText',
onSearch: '&?mdSearch',
placeholder: '@placeholder',
delay: '@delay'
},
template:'<div class="md-search-input" layout="row">\
<input type="text" flex autocomplete="off" ng-model="searchText" name="{{inputName}}" placeholder="{{placeholder}}" ng-change="on_changed()" />\
<md-button class="md-fab" ng-click="on_clear()" ng-show="searchText!==\'\'"><md-icon md-svg-icon="md-close" style="color:rgba(0,0,0,0.5);"></md-icon></md-button>\
</div>',
link:function($scope, $element){
}
};
}]);

CSS 样式:

.md-search-input{
box-sizing: border-box;border: none;box-shadow: none;background: 0 0; border-radius:5px;background: #FFF;margin:0px;position: relative;
input{outline: 0;font-size: 14px; width: 100%; padding: 0 15px; line-height: 40px;height: 40px;border: none;background:transparent;}
button,.md-fab,.md-button,button:hover,.md-fab:hover {
background:transparent !important;
line-height:40px;height:40px;width:40px;font-size:14px;box-shadow:none !important;margin:0px;padding:0px;
color:rgba(0,0,0,0.5) !important;
}
}

配合 ng-route 可以很容易实现无刷新的APP 让您的web页面更加接近app体验,
在 maincontroll中,通过监听 ng-route 的页面即将跳转事件 来重置消息框,

//在页面改变之前,重置搜索框.
$scope.$on('SearchText.Reset',function(){ $scope.searchConfig={show:false, key:'',delay:1200};});
$rootScope.$on('$routeChangeStart', function (event, next) {
$rootScope.$broadcast('SearchText.Reset');
});

而在需要用到搜索功能的地方,则只需要在控制器里通过如下代码实现:

//陪值搜索框为己用
$scope.$emit('Search.Config',{
show:true, key:'',delay:800,
emptyText:"请输入:商家名称,账号,电话 等内容以进行搜索.",
onSearch: function(){
return function(v){
$scope.merData.query(v); //调用本控制器的数据查询接口.
}
}
});

以上所述是小编给大家介绍的Angularjs material 实现搜索框功能,希望对大家有所帮助!

以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索angularjs_material
angularjs搜索功能
angularjs实现搜索框、angularjs 实现搜索、angularjs material、angularjs material2、angularjs实现tab切换,以便于您获取更多的相关知识。

时间: 2024-11-02 21:21:49

Angularjs material 实现搜索框功能_AngularJS的相关文章

《React Native移动开发实战》一一3.2 完善搜索框功能——TextInput组件

3.2 完善搜索框功能--TextInput组件 重构代码完毕后,就可以"轻装上阵",更快更好地为应用添加新功能了.按照之前首页结构的划分,先来看看搜索框.搜索框分为输入框和搜索按钮两部分,如图3.6所示. 图3.6 搜索框的结构 用户在输入框输入要搜索的关键字后,单击"搜索"按钮,即可按照输入框中的关键字进行搜索.3.2.1 搜索提示框 为了实现这样的效果,可以使用TextInput组件的onChangeText()方法.当输入框内容变化时会调用此回调函数,改变后

AngularJs页面筛选标签小功能_AngularJS

AngularJS 简介 AngularJS 是一个 JavaScript 框架.它可通过 <script> 标签添加到 HTML 页面. AngularJS 通过 指令 扩展了 HTML,且通过 表达式 绑定数据到 HTML. AngularJS 是一个 JavaScript 框架 AngularJS 是一个 JavaScript 框架.它是一个以 JavaScript 编写的库. AngularJS 是以一个 JavaScript 文件形式发布的,可通过 script 标签添加到网页中:

基于AngularJS+HTML+Groovy实现登录功能_AngularJS

AngularJS是开发基于浏览器的响应式RWD应用程序的一个前端MVC框架,由谷歌最初开发的 开源项目,干净的架构吸引了大量粉丝,适合建立CRUD类型的业务应用程序,并不适合开发游戏等应用, 使用声明性编程的用户界面和命令式编程的逻辑, 支持现代桌面和移动浏览器 Internet Explorer版本8.0及以上. AngularJS是一款客户端MVC的javascript框架,而客户端MVC代表未来架构(为什么要使用MVC+REST+CQRS 架构),如果你有Struts或SpringMVC

jquery中用jsonp实现搜索框功能_jquery

前面的话:     在上周本来想发一篇模仿必应搜索的界面.但是在准备写文章之前突然想到前面学习了ajax技术,在这里我也让我的页面有一种不需要手动刷新就能获取到数据.但是发现用前面的方法并不能获取到我想要的效果.无奈前几天电脑换系统,把之前的源码丢了(前面有个不好的习惯就是把最近在做的东西放桌面).今天想彻底把这个问题搞明白. 用jquery和ajax进行初步的尝试: (本代码是参考慕课网,搜索框制作视频制作,有关具体详情请参考视频.自己之前的代码找不到了,之前最先的想法也是来自那里,所以这次直

Windows 7开始菜单中搜索框和文件夹中搜索框功能有什么区别呢

    一样的搜索框,放到不同位置,就带上不同的搜索范围.这让才上手的用户变得不太适应,甚至有些顾客觉得windows7的搜索不好用.但是仔细查看一下,发现开始菜单中的搜索框和文件夹中的搜索框,还是有区别的.   同样的搜索框的模样,但开始菜单中的搜索框的职责并不是搜索整个硬盘,而是兼具搜索:windows文件夹.program file文件夹.path环境变量指向的文件夹.libraries.run历史里面搜索文件,甚至可以接受"控制面板命令".充当运行对话框的作用!所以说,这里的搜

用jsonp实现搜索框功能的例子

   在上周本来想发一篇模仿必应搜索的界面.但是在准备写文章之前突然想到前面学习了ajax技术,在这里我也让我的页面有一种不需要手动刷新就能获取到数据.但是发现用前面的方法并不能获取到我想要的效果.无奈前几天电脑换系统,把之前的源码丢了(前面有个不好的习惯就是把最近在做的东西放桌面).今天想彻底把这个问题搞明白. 用jquery和ajax进行初步的尝试: (本代码是参考慕课网,搜索框制作视频制作,有关具体详情请参考视频.自己之前的代码找不到了,之前最先的想法也是来自那里,所以这次直接用那里的代码

AngularJS实现星星等级评分功能_AngularJS

星期六加班,教育后台也要有星级评分等级的需求,醉了--基本知道些怎么做,网上也随便找了找,没什么合意的,毕竟需求不同,也不能完全一样不是.学习之,改之╮(╯▽╰)╭ Directive  angular.module('XXX').directive('stars', stars); function stars() { var directive = { restrict: 'AE', template: '<ul class="rating" ng-mouseleave=&q

利用Angularjs和bootstrap实现购物车功能_AngularJS

先来看看效果图: 购物车 一.代码 如果看了这个效果有兴趣想知道怎么做出来的话,那就继续往下看吧.话不多少,直接上代码. html代码: <!DOCTYPE html> <html lang="en" ng-app="cart"> <head> <meta charset="UTF-8"> <title>购物车</title> <link rel="style

AngularJS实现全选反选功能_AngularJS

AngularJS是为了克服HTML在构建应用上的不足而设计的.HTML是一门很好的为静态文本展示设计的声明式语言,但要构建WEB应用的话它就显得乏力了.所以我做了一些工作(你也可以觉得是小花招)来让浏览器做我想要的事. 这里用到AngularJS四大特性之二----双向数据绑定 注意:没写一行DOM代码!这就是ng的优点,bootstrap.css为了布局,JS代码也只是简单创建ng模块和ng控制器 效果: <!DOCTYPE html> <html lang="en&quo