jquery使用案例
表单验证
Dom实现表单验证
通过在form标签的submit上绑定一个onclick事件,用户点击事,触发这个事件,执行Checkvalid()函数进行对表单中的元素值验证,验证通过之后,继续让submit之行自己的事件,post表单内容到服务器,如果验证不通过,则返回false,终止submit继续提交
- 代码:
- <!DOCTYPE html>
- <html lang="en">
- <head>
- <meta charset="UTF-8">
- <title>Title</title>
- <style>
- .iterm {
- width: 250px;
- height: 60px;
- position: relative;
- }
- .iterm input {
- width: 200px;
- }
- .iterm span {
- position: absolute;
- top: 20px;
- left: 0px;
- background-color: red;
- font-size: 8px;
- color: white;
- display: inline-block;
- width: 202px;
- }
- </style>
- </head>
- <body>
- <div>
- <form>
- <div class="iterm">
- <input class="c1" type="text" name="username" lable="用户名"/>
- <!--<span>用户名不能为空</span>-->
- </div>
- <div class="iterm">
- <input class="c1" type="password" name="password" lable="密码" />
- <!--<span>密码不能为空</span>-->
- </div>
- <input type="submit" name="提交">
- </form>
- </div>
- </body>
- <script src="jquery-1.12.4.js"></script>
- <script>
- $(function() {
- //当页面框架加载完成之后,自动执行
- BindCheckvalid();
- });
- function BindCheckvalid() {
- $('form input[type="submit"]').click(function () {
- //点击submit,执行下面内容
- var flag = true;
- $('form .iterm span').remove(); // 清空之前出现的错误提示
- $('form .c1').each(function() {
- //每一个元素执行匿名函数
- //this 循环的当前元素
- var val = $(this).val();
- if (val.length <= 0){
- var name = $(this).attr('lable');
- var tag = document.createElement('span');
- tag.innerText = name + '不能为空';
- $(this).after(tag);
- flag = false;
- return flag; //只要有一个验证不合法,终止验证
- };
- });
- return false;
- });
- };
- </script>
- </html>
jQuery实现表单验证
- html代码:
- <!DOCTYPE html>
- <html lang="en">
- <head>
- <meta charset="UTF-8">
- <title></title>
- <style>
- .item{
- width: 250px;
- height: 60px;
- position: relative;
- }
- .item input{
- width: 200px;
- }
- .item span{
- position: absolute;
- top: 20px;
- left: 0px;
- font-size: 8px;
- background-color: indianred;
- color: white;
- display: inline-block;
- width: 200px;
- }
- </style>
- </head>
- <body>
- <div>
- <form id="form1">
- <div class="item">
- <input class="c1" type="text" name="username" label="用户名" require="true" min-len="6"/>
- </div>
- <div class="item">
- <input class="c1" type="password" name="pwd" label="密码"/>
- </div>
- <div class="item">
- <input class="c1" type="text" name="phone" label="手机" require="true" phone="true"/>
- </div>
- <input type="submit" value="提交" />
- </form>
- </div>
- <script src="jquery-1.12.4.js"></script>
- <script src="commons1.js"></script>
- <script>
- $(function(){
- $.valid('#form1');
- });
- </script>
- </body>
- </html>
- js代码
- /**
- * Created by fuzj on 2016/9/3.
- */
- (function(jq){
- function ErrorMessage(inp,message){
- var tag = document.createElement('span');
- tag.innerText = message;
- inp.after(tag);
- }
- jq.extend({
- valid:function(form){
- // #form1 $('#form1')
- jq(form).find(':submit').click(function(){
- jq(form).find('.item span').remove();
- var flag = true;
- jq(form).find(':text,:password').each(function(){
- var require = $(this).attr('require');
- if(require){
- var val = $(this).val();
- if(val.length<=0){
- var label = $(this).attr('label');
- ErrorMessage($(this),label + "不能为空");
- flag = false;
- return false;
- }
- var minLen = $(this).attr('min-len');
- if(minLen){
- var minLenInt = parseInt(minLen);
- if(val.length<minLenInt){
- var label = $(this).attr('label');
- ErrorMessage($(this),label + "长度最小为"+ minLen);
- flag = false;
- return false;
- }
- //json.stringify()
- //JSON.parse()
- }
- var phone = $(this).attr('phone');
- if(phone){
- // 用户输入内容是否是手机格式
- var phoneReg = /^1[3|5|8]\d{9}$/;
- if(!phoneReg.test(val)){
- var label = $(this).attr('label');
- ErrorMessage($(this),label + "格式错误");
- flag = false;
- return false;
- }
- }
- // 1、html自定义标签属性
- // 增加验证规则+错误提示
- }
- // 每一个元素执行次匿名函数
- // this
- //console.log(this,$(this));
- /*
- var val = $(this).val();
- if(val.length<=0){
- var label = $(this).attr('label');
- var tag = document.createElement('span');
- tag.innerText = label + "不能为空";
- $(this).after(tag);
- flag = false;
- return false;
- }
- */
- });
- return flag;
- });
- }
- });
- })(jQuery);
滚动菜单
- <!DOCTYPE html>
- <html>
- <head lang="en">
- <meta charset="UTF-8">
- <title></title>
- <style>
- body{
- margin: 0px;
- }
- img {
- border: 0;
- }
- ul{
- padding: 0;
- margin: 0;
- list-style: none;
- }
- .clearfix:after {
- content: ".";
- display: block;
- height: 0;
- clear: both;
- visibility: hidden;
- }
- .wrap{
- width: 980px;
- margin: 0 auto;
- }
- .pg-header{
- background-color: #303a40;
- -webkit-box-shadow: 0 2px 5px rgba(0,0,0,.2);
- -moz-box-shadow: 0 2px 5px rgba(0,0,0,.2);
- box-shadow: 0 2px 5px rgba(0,0,0,.2);
- }
- .pg-header .logo{
- float: left;
- padding:5px 10px 5px 0px;
- }
- .pg-header .logo img{
- vertical-align: middle;
- width: 110px;
- height: 40px;
- }
- .pg-header .nav{
- line-height: 50px;
- }
- .pg-header .nav ul li{
- float: left;
- }
- .pg-header .nav ul li a{
- display: block;
- color: #ccc;
- padding: 0 20px;
- text-decoration: none;
- font-size: 14px;
- }
- .pg-header .nav ul li a:hover{
- color: #fff;
- background-color: #425a66;
- }
- .pg-body{
- }
- .pg-body .catalog{
- position: absolute;
- top:60px;
- width: 200px;
- background-color: #fafafa;
- bottom: 0px;
- }
- .pg-body .catalog.fixed{
- position: fixed;
- top:10px;
- }
- .pg-body .catalog .catalog-item.active{
- color: #fff;
- background-color: #425a66;
- }
- .pg-body .content{
- position: absolute;
- top:60px;
- width: 700px;
- margin-left: 210px;
- background-color: #fafafa;
- overflow: auto;
- }
- .pg-body .content .section{
- height: 500px;
- }
- </style>
- </head>
- <body>
- <div class="pg-header">
- <div class="wrap clearfix">
- <div class="logo">
- <a href="#">
- <img src="">
- </a>
- </div>
- <div class="nav">
- <ul>
- <li>
- <a href="#">首页</a>
- </li>
- <li>
- <a href="#">功能一</a>
- </li>
- <li>
- <a href="#">功能二</a>
- </li>
- </ul>
- </div>
- </div>
- </div>
- <div class="pg-body">
- <div class="wrap">
- <div class="catalog">
- <div class="catalog-item" auto-to="function1"><a>第1张</a></div>
- <div class="catalog-item" auto-to="function2"><a>第2张</a></div>
- <div class="catalog-item" auto-to="function3"><a>第3张</a></div>
- </div>
- <div class="content">
- <div menu="function1" class="section" style='background-color:green;'>
- <h1>第一章</h1>
- </div>
- <div menu="function2" class="section" style='background-color:yellow;'>
- <h1>第二章</h1>
- </div>
- <div menu="function3" class="section" style='background-color:red;'>
- <h1>第三章</h1>
- </div>
- </div>
- </div>
- </div>
- <script type="text/javascript" src="jquery-1.8.2.min.js"></script>
- <script type="text/javascript">
- $(function(){
- // 自动执行
- Init();
- });
- function Init(){
- $(window).scroll(function() {
- // 监听窗口滚动事件
- // 获取滚动条高度
- var scrollTop = $(window).scrollTop();
- // 当滚动到50像素时,左侧带菜单固定
- if(scrollTop > 50){
- $('.catalog').addClass('fixed');
- }else{
- $('.catalog').children().removeClass('active');
- $('.catalog').removeClass('fixed');
- }
- // 循环所有的内容
- $('.content').children().each(function(){
- // 当前标签距离顶部高度
- var offSet = $(this).offset(); // 高度,左边有多远
- // offSet.top
- // offSet.left
- // 自身高度
- var height = $(this).height();
- //offSet<滚动高度<offSet+height
- // 当前内容位于用户阅览区
- if(scrollTop>offSet.top && scrollTop< offSet.top + height){
- // $(this) 当前内容标签
- /*
- var target = $(this).attr('menu');
- $('.catalog').find('div[auto-to="'+target+'"]').addClass('active').siblings().removeClass('active');
- return false;
- */
- var docHeight = $(document).height();
- var winHeight = $(window).height();
- // 如果,滚轮到达底部,则显示最后一个菜单
- if(docHeight == winHeight+scrollTop)
- {
- $('.catalog').find('div:last-child').addClass('active').siblings().removeClass('active');
- }else{
- var target = $(this).attr('menu');
- $('.catalog').find('div[auto-to="'+target+'"]').addClass('active').siblings().removeClass('active');
- }
- return false;
- }
- });
- });
- }
- </script>
- </body>
- </html>
补充:Javascript正则表达式
定义正则表达式
- /.../ 用于定义正则表达式
- /.../g 表示全局匹配
- /.../i 表示不区分大小写
- /.../m 表示多行匹配 JS正则匹配时本身就是支持多行,此处多行匹配只是影响正则表达式和\(,m模式也会使用^\)来匹配换行的内容)
- var pattern = /^Java\w*/gm;
- var text = "JavaScript is more fun than \nJavaEE or JavaBeans!";
- pattern.exec(text)
- ["JavaScript"]
- pattern.exec(text)
- ["JavaEE"]
- pattern.exec(text)
- null
- var pattern = /^Java\w*/g;
- undefined
- var text = "JavaScript is more fun than \nJavaEE or JavaBeans!";
- undefined
- pattern.exec(text)
- ["JavaScript"]
- pattern.exec(text)
- null
注:定义正则表达式也可以 reg= new RegExp()
匹配正则
JavaScript中支持正则表达式,其主要提供了两个功能:
- test(string) 检查字符串中是否和正则匹配
- n = 'uui99sdf'
- reg = /\d+/
- reg.test(n) ---> true
- # 只要正则在字符串中存在就匹配,如果想要开头和结尾匹配的话,就需要在正则前后加 ^和$
- exec(string) 获取正则表达式匹配的内容,如果未匹配,值为null,否则,获取匹配成功的数组
获取正则表达式匹配的内容,如果未匹配,值为null,否则,获取匹配成功的数组。
- 非全局模式
- 获取匹配结果数组,注意:第一个元素是第一个匹配的结果,后面元素是正则子匹配(正则内容分组匹配)
- var pattern = /\bJava\w*\b/;
- var text = "JavaScript is more fun than Java or JavaBeans!";
- result = pattern.exec(text)
- var pattern = /\b(Java)\w*\b/;
- var text = "JavaScript is more fun than Java or JavaBeans!";
- result = pattern.exec(text)
- 全局模式
- 需要反复调用exec方法,来一个一个获取结果,直到匹配获取结果为null表示获取完毕
- var pattern = /\bJava\w*\b/g;
- var text = "JavaScript is more fun than Java or JavaBeans!";
- result = pattern.exec(text)
- var pattern = /\b(Java)\w*\b/g;
- var text = "JavaScript is more fun than Java or JavaBeans!";
- result = pattern.exec(text)
- 字符串相关操作
- obj.search(regexp) 获取索引位置,搜索整个字符串,返回匹配成功的第一个位置(g模式无效)
- obj.match(regexp) 获取匹配内容,搜索整个字符串,获取找到第一个匹配内容,如果正则是g模式找到全部
- obj.replace(regexp, replacement) 替换匹配替换,正则中有g则替换所有,否则只替换第一个匹配项,
- $数字:匹配的第n个组内容;
- $&:当前匹配的内容;
- $`:位于匹配子串左侧的文本;
- $':位于匹配子串右侧的文本
- $$:直接量$符号
- 常用正则表达式
- 整数或者小数:^[0-9]+\.{0,1}[0-9]{0,2}$
- 只能输入数字:"^[0-9]*$"。
- 只能输入n位的数字:"^\d{n}$"。
- 只能输入至少n位的数字:"^\d{n,}$"。
- 只能输入m~n位的数字:。"^\d{m,n}$"
- 只能输入零和非零开头的数字:"^(0|[1-9][0-9]*)$"。
- 只能输入有两位小数的正实数:"^[0-9]+(.[0-9]{2})?$"。
- 只能输入有1~3位小数的正实数:"^[0-9]+(.[0-9]{1,3})?$"。
- 只能输入非零的正整数:"^\+?[1-9][0-9]*$"。
- 只能输入非零的负整数:"^\-[1-9][]0-9"*$。
- 只能输入长度为3的字符:"^.{3}$"。
- 只能输入由26个英文字母组成的字符串:"^[A-Za-z]+$"。
- 只能输入由26个大写英文字母组成的字符串:"^[A-Z]+$"。
- 只能输入由26个小写英文字母组成的字符串:"^[a-z]+$"。
- 只能输入由数字和26个英文字母组成的字符串:"^[A-Za-z0-9]+$"。
- 只能输入由数字、26个英文字母或者下划线组成的字符串:"^\w+$"。
- 验证用户密码:"^[a-zA-Z]\w{5,17}$"正确格式为:以字母开头,长度在6~18之间,只能包含字符、数字和下划线。
- 验证是否含有^%&',;=?$\"等字符:"[^%&',;=?$\x22]+"。
- 只能输入汉字:"^[\u4e00-\u9fa5]{0,}$"
- 验证Email地址:"^\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$"。
- 验证InternetURL:"^http://([\w-]+\.)+[\w-]+(/[\w-./?%&=]*)?$"。
- 验证电话号码:"^(\(\d{3,4}-)|\d{3.4}-)?\d{7,8}$"正确格式为:"XXX-XXXXXXX"、"XXXX-XXXXXXXX"、"XXX-XXXXXXX"、"XXX-XXXXXXXX"、"XXXXXXX"和"XXXXXXXX"。
- 验证身份证号(15位或18位数字):"^\d{15}|\d{18}$"。
- 验证一年的12个月:"^(0?[1-9]|1[0-2])$"正确格式为:"01"~"09"和"1"~"12"。
- 验证一个月的31天:"^((0?[1-9])|((1|2)[0-9])|30|31)$"正确格式为;"01"~"09"和"1"~"31"。 匹配中文字符的正则表达式: [\u4e00-\u9fa5]
- 匹配双字节字符(包括汉字在内):[^\x00-\xff]
- 匹配空行的正则表达式:\n[\s| ]*\r
- 匹配html标签的正则表达式:<(.*)>(.*)<\/(.*)>|<(.*)\/>
- 匹配首尾空格的正则表达式:(^\s*)|(\s*$)
- 匹配Email地址的正则表达式:\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*
- 匹配网址URL的正则表达式:http://([\w-]+\.)+[\w-]+(/[\w- ./?%&=]*)?
- 利用正则表达式限制网页表单里的文本框输入内容:
- 用正则表达式限制只能输入中文:onkeyup="value=value.replace(/[^\u4E00-\u9FA5]/g,'')" onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\u4E00-\u9FA5]/g,''))"
- 用正则表达式限制只能输入全角字符: onkeyup="value=value.replace(/[^\uFF00-\uFFFF]/g,'')" onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\uFF00-\uFFFF]/g,''))"
- 用正则表达式限制只能输入数字:onkeyup="value=value.replace(/[^\d]/g,'') "onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\d]/g,''))"
- 用正则表达式限制只能输入数字和英文:onkeyup="value=value.replace(/[\W]/g,'') "onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\d]/g,''))"
- 匹配中文字符的正则表达式: [\u4e00-\u9fa5]
- 匹配双字节字符(包括汉字在内):[^\x00-\xff]
- 匹配空白行的正则表达式:\n\s*\r
- 匹配HTML标记的正则表达式:<(\S*?)[^>]*>.*?|<.*? />
- 匹配首尾空白字符的正则表达式:^\s*|\s*$
- 匹配Email地址的正则表达式:\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*
- 匹配网址URL的正则表达式:[a-zA-z]+://[^\s]*
- 匹配帐号是否合法(字母开头,允许5-16字节,允许字母数字下划线):^[a-zA-Z][a-zA-Z0-9_]{4,15}$
- 匹配国内电话号码:\d{3}-\d{8}|\d{4}-\d{7}
- 匹配腾讯QQ号:[1-9][0-9]{4,}
- 匹配中国邮政编码:[1-9]\d{5}(?!\d)
- 匹配身份证:\d{15}|\d{18}
- Email : /^\w+([-+.]\w+)*@\w+([-.]\\w+)*\.\w+([-.]\w+)*$/
- isEmail1 : /^\w+([\.\-]\w+)*\@\w+([\.\-]\w+)*\.\w+$/;
- isEmail2 : /^.*@[^_]*$/;
- Phone : /^((\(\d{3}\))|(\d{3}\-))?(\(0\d{2,3}\)|0\d{2,3}-)?[1-9]\d{6,7}$/
- Mobile : /^((\(\d{3}\))|(\d{3}\-))?13\d{9}$/
- Url : /^http:\/\/[A-Za-z0-9]+\.[A-Za-z0-9]+[\/=\?%\-&_~`@[\]\':+!]*([^<>\"\"])*$/
- IdCard : /^\d{15}(\d{2}[A-Za-z0-9])?$/
- Currency : /^\d+(\.\d+)?$/
- Number : /^\d+$/
- Code : /^[1-9]\d{5}$/
- QQ : /^[1-9]\d{4,8}$/
- Integer : /^[-\+]?\d+$/
- Double : /^[-\+]?\d+(\.\d+)?$/
- English : /^[A-Za-z]+$/
- Chinese : /^[\u0391-\uFFE5]+$/
- UnSafe : /^(([A-Z]*|[a-z]*|\d*|[-_\~!@#\$%\^&\*\.\(\)\[\]\{\}<>\?\\\/\'\"]*)|.{0,5})$|\s/
- PassWord :^[\\w]{6,12}$
- ZipCode : ^[\\d]{6}
- /^(\+\d+ )?(\(\d+\) )?[\d ]+$/; //这个是国际通用的电话号码判断
- /^(1[0-2]\d|\d{1,2})$/; //这个是年龄的判断
- /^\d+\.\d{2}$/; //这个是判断输入的是否为货币值
- <!-- IP地址有效性验证函数-->
- <script language=javascript runat=server>
- ip_ip = '(25[0-5]|2[0-4]\\d|1\\d\\d|\\d\\d|\\d)';
- ip_ipdot = ip + '\\.';
- isIPaddress = new RegExp('^'+ip_ipdot+ip_ipdot+ipdot+ip_ip+'$');
- </script>
- 匹配空行的正则表达式:\n[\s| ]*\r
- 匹配HTML标记的正则表达式:/<(.*)>.*<\/\1>|<(.*) \/>/
- 匹配首尾空格的正则表达式:(^\s*)|(\s*$)
- 匹配Email地址的正则表达式:\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*
- 匹配网址URL的正则表达式:http://([\w-]+\.)+[\w-]+(/[\w- ./?%&=]*)?
- 前端插件介绍
fontawsome 各种图标
easyui
jqueryui
bootstrap
bxslider
jquerylazyload
jquery使用案例的更多相关文章
- 中国省市区地址三级联动jQuery插件 案例下载
中国省市区地址三级联动jQuery插件 案例下载 distpicker 是一款可以实现中国省市区地址三级联动jQuery插件.它使用简单,简单设置即可完成中国省市区地址联动效果. 安装 可以通过npm ...
- jQuery常见案例
jQuery常见案例 通过jQuery实现全选,反选取消: 选择 地址 端口 1.1.1.1 80 1.1.1.1 80 1.1.1.1 80 1.1.1.1 80 代码实现 <body> ...
- Jquery 分页案例
Jquery 分页案例 <!DOCTYPE html> <html> <head> <meta charset="utf-8" /& ...
- jQuery的案例及必知重要的jQuery选择器
Jquery能做什么 访问和操作DOM元素 控制页面样式 对页面事件进行处理 扩展新的jQuery插件 与Ajax技术完美结合 Jquery的优势 体积小,压缩后只有100KB左右 l强大的选择器 出 ...
- jQuery Mobile案例,最近用Moon.Web和Moon.Orm做了一套系统
一.简介 先说说,我们的主题.jQuery Mobile,最近用Moon.Web和Moon.Orm做了一套系统 jQuery Mobile是jQuery 在手机上和平板设备上的版本.jQuery ...
- jquery选择器案例
一.预期效果 实现一个效果,如下. 品牌列表默认精简显示,单击“显示全部品牌”按钮显示全部品牌,同时列表将推荐的品牌的名字高亮显示,按钮里的文字变成“精简显示品牌”.再次点击“精简显示品牌”回到初始页 ...
- jQuery 简单案例
案例一:全选.反选.取消实例 <!DOCTYPE html> <html lang="en"> <head> <meta charset= ...
- 毕业设计---json,Struts,ajax以及JQuery简单案例
<!-- Struts2的xml文件配置 --><struts> <package name="default" namespace="/& ...
- jQuery高级案例
一.广告的自动显示与隐藏 <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> ...
随机推荐
- UITableView cell复用出错问题 页面滑动卡顿问题 & 各杂七杂八问题
UITableView 的cell 复用机制节省了内存,但是有时对于多变的自定义cell,重用时会出现界面出错(例如复用出错,出现cell混乱重影).滑动卡顿等问题,这里只简单敲下几点复用出错时的解决 ...
- javascript 设置input框只读属性 获取disabled后的值并传给后台
input只读属性 有两种方式可以实现input的只读效果:disabled 和 readonly. 自然两种出来的效果都是只能读取不能编辑,可是两者有很大不同. Disabled说明该input ...
- Node.js 教程 06 - 函数
前言: 本篇介绍的是Node.js中的函数,相对于上一篇会简单一点,其实和我们Javascript中的function无异. 好了,废话不多说了,我们进入正题吧. Node.js函数: [示例1:创建 ...
- Oracle XMLTable 使用教程与实例
从Oracle 10g开始,甲骨文公司新增了XQuery和XMLTable两个功能作为处理XML的武器. XMLQuery一样,您可以使用XQuery语言构造XML数据和查询XML和关系数据.你可以使 ...
- 在Ubuntu X64上编译Hadoop
在之前的文章中介绍了如何直接在Ubuntu中安装Hadoop.但是对于64位的Ubuntu来说,官方给出的Hadoop包是32位的,运行时会得到警告: WARN util.NativeCodeLoad ...
- MySQL优化一例
DELIMITER $$ USE `xxx`$$ DROP FUNCTION IF EXISTS `F_getBuluDates`$$ CREATE DEFINER=`root`@`localhost ...
- C# 闭包问题-你被”坑“过吗?
引言 闭包是什么?以前看面试题的时候才发现这个名词. 闭包在实际项目中会有什么问题?现在就让我们一起来看下这个不太熟悉的名词. 如果在实际工作中用到了匿名函数和lamada表达式,那你就应该高度注意啦 ...
- 【js】初入AJAX
AJAX即“Asynchronous Javascript And XML”(异步JavaScript和XML),是指一种创建交互式网页应用的网页开发技术. AJAX = 异步 JavaScript和 ...
- java中transient关键字的作用
Java有个特点就是序列化,简单地来说就是可以将这个类存储在物理空间(当然还是以文件的形式存在),那么当你从本地还原这个文件时,你可以将它转换为它本身.这可以极大地方便网络上的一些操作,但同时,因为涉 ...
- [LeetCode] Anagrams 错位词
Given an array of strings, return all groups of strings that are anagrams. Note: All inputs will be ...