var app = angular.module('app',['ngSanitize']); app.controller('searchCtrl',['$scope', function($scope){ $scope.searchContents = [ { title: 'Hedng one', disc_1: 'Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmodtempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam,quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodoconsequat. Duis aute irure dolor in reprehenderit in voluptate velit essecillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat nonproident, sunt in culpa qui officia deserunt mollit anim id est laborum.' }, { title: 'Heading tow', disc_1: 'Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmodtempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam,quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodoconsequat. Duis aute irure dolor in reprehenderit in voluptate velit essecillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat nonproident, sunt in culpa qui officia deserunt mollit anim id est laborum.', disc_2: 'Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmodtempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam,quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodoconsequat. Duis aute irure dolor in reprehenderit in voluptate velit essecillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat nonproident, sunt in culpa qui officia deserunt mollit anim id est laborum.', disc_3: 'lorem lorem lorem' }, { title: 'Heding three', disc_1: 'discription..............................................' }, { title: 'Heding four', disc_1: 'discription..............................................' } ]; }]); app.filter('highlight', function () { return function (text, search, caseSensitive) { if (text && (search || angular.isNumber(search))) { text = text.toString(); search = search.toString(); if (caseSensitive) { return text.split(search).join('<span class="ui-match">' + search + '</span>'); } else { return text.replace(new RegExp(search, 'gi'), '<span class="ui-match">$&</span>'); } } else { return text; } }; });
/* Generated by less 2.5.1 */ .ui-match { background: #FFC107; color: #fff; } .side-panel.panel-open { transform: translateX(0%); display: block; } .side-panel li { float: left; width: 100%; } .side-panel.side-panel-singlar { z-index: 10; } .search-results > ul { list-style: none; padding: 0; margin: 5%; } .search-results > li { line-height: 1.3em; }
<!DOCTYPE html> <html> <head> <script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.3.0-beta.1/angular.min.js"></script> <script src="https://cdnjs.cloudflare.com/ajax/libs/angular.js/1.2.20/angular-sanitize.min.js"></script> <script type="text/javascript" src="js/script.js"></script> <link rel="stylesheet" type="text/css" href="js/style.css"> <meta charset="utf-8"> <title>JS Bin</title> </head> <body> <div ng-app="app" ng-controller="searchCtrl"> <div class="side-panel-singla"> <input type="text" class="input-search" placeholder="Search..." ng-model="searchText" /> <button class="btn-search">search</button> <div ng-repeat="searchContent in searchContents | filter:searchText"> <ul> <li> <h3 ng-bind-html="searchContent.title | highlight:searchText"></h3> <p ng-bind-html="searchContent.disc_1 | highlight:searchText"></p> <p ng-bind-html="searchContent.disc_2 | highlight:searchText"></p> </li> </ul> </div> </div> </div> </body> </html>
What follows is a very specific solution for your case. I added class called hastext
to the style sheet, and then I added an long ng-class directive to a new <div>
around the paragraph <p>s
It's nice because it utilizes your highlight filter, comparing the filtered text to the original, and setting it to true if there's a difference (if it finds any of the inserted <span>s
). However, if you add more paragraphs, you will also have to add additional lines to that ng-class call.
var app = angular.module('app',['ngSanitize']); app.controller('searchCtrl',['$scope', function($scope){ $scope.searchContents = [ { title: 'Hedng one', disc_1: 'Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmodtempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam,quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodoconsequat. Duis aute irure dolor in reprehenderit in voluptate velit essecillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat nonproident, sunt in culpa qui officia deserunt mollit anim id est laborum.' }, { title: 'Heading tow', disc_1: 'Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmodtempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam,quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodoconsequat. Duis aute irure dolor in reprehenderit in voluptate velit essecillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat nonproident, sunt in culpa qui officia deserunt mollit anim id est laborum.', disc_2: 'Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmodtempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam,quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodoconsequat. Duis aute irure dolor in reprehenderit in voluptate velit essecillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat nonproident, sunt in culpa qui officia deserunt mollit anim id est laborum.', disc_3: 'lorem lorem lorem' }, { title: 'Heding three', disc_1: 'discription..............................................' }, { title: 'Heding four', disc_1: 'discription..............................................' } ]; }]); app.filter('highlight', function () { return function (text, search, caseSensitive) { if (text && (search || angular.isNumber(search))) { text = text.toString(); search = search.toString(); if (caseSensitive) { return text.split(search).join('<span class="ui-match">' + search + '</span>'); } else { return text.replace(new RegExp(search, 'gi'), '<span class="ui-match">$&</span>'); } } else { return text; } }; });
/* Generated by less 2.5.1 */ .ui-match { background: #FFC107; color: #fff; } .side-panel.panel-open { transform: translateX(0%); display: block; } .side-panel li { float: left; width: 100%; } .side-panel.side-panel-singlar { z-index: 10; } .search-results > ul { list-style: none; padding: 0; margin: 5%; } .search-results > li { line-height: 1.3em; } .paragraphs { height: 0; overflow-y: hidden; } .paragraphs.hastext { height: auto; }
<!DOCTYPE html> <html> <head> <script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.3.0-beta.1/angular.min.js"></script> <script src="https://cdnjs.cloudflare.com/ajax/libs/angular.js/1.2.20/angular-sanitize.min.js"></script> <script type="text/javascript" src="js/script.js"></script> <link rel="stylesheet" type="text/css" href="js/style.css"> <meta charset="utf-8"> <title>JS Bin</title> </head> <body> <div ng-app="app" ng-controller="searchCtrl"> <div class="side-panel-singla"> <input type="text" class="input-search" placeholder="Search..." ng-model="searchText" /> <button class="btn-search">search</button> <div ng-repeat="searchContent in searchContents" > <ul> <li> <h3 ng-bind-html="searchContent.title | highlight:searchText" ></h3> <div class="paragraphs" ng-class="{'hastext' : ((searchContent.title | highlight:searchText) != searchContent.title || (searchContent.disc_1 | highlight:searchText) != searchContent.disc_1 || (searchContent.disc_2 | highlight:searchText) != searchContent.disc_2 )}"> <p ng-bind-html="searchContent.disc_1 | highlight:searchText"></p> <p ng-bind-html="searchContent.disc_2 | highlight:searchText"></p> </div> </li> </ul> </div> </div> </div> </body> </html>
The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.