热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Angular+Bootstrap神奇小弹窗功能

好久没写博客了,可能是我懒了,emmm。。。前几天接到了一个新的需求,其中有一个弹窗挺有意思的,来这里跟大家分享一下。如果V

好久没写博客了,可能是我懒了,emmm。。。
前几天接到了一个新的需求,其中有一个弹窗挺有意思的,来这里跟大家分享一下。如果Vue的话可能直接很多框架中都是写好的,我们的框架呢是一个比较老的Angular2.几的+Bootstrap的框架。说实话呢。我对这个了解也不是特别深。闲话少叙,来看看这个有意思的小弹框功能。
需求是这样的
在这里插入图片描述
我们主要关注这个详情,需求是这样的意思:
1)当文本框中的文字超过3个时候,显示*…详情*,这个详情可能在这个页面多次出现,
2)当点击详情时候弹出框提示除了这3个地方之外区域名称
3)点击其他位置或者点击另一个详情的时候,取消这个弹框显示,如果是点击另一个详情,在另一个详情上方显示2)的意思。
这个需求呢?其实没啥。直接找一个组件一添加显示不就行了么(天真了,这个里边并没有这个样式和功能的弹框),被迫自己写吧。

上代码然后简单说一下我的思路

<div class&#61;"modal fade" id&#61;"delreason1" tabindex&#61;"-1" role&#61;"dialog" data-backdrop&#61;"static" ng-click&#61;"hidetriangle()"><div class&#61;"modal-dialog" role&#61;"document" style&#61;"width: 1000px;"><div class&#61;"modal-content"><div class&#61;"modal-header"><button type&#61;"button" class&#61;"close" data-dismiss&#61;"modal" >×</button><h4 class&#61;"modal-title" id&#61;"myModalLabel_update" style&#61;"text-align: center">上架中介管理</h4></div><div class&#61;"modal-body"> <fieldset><div class&#61;"ibox-content track-fieldset-top"><div style&#61;"overflow-y:scroll"><table class&#61;" table-striped table tablee"><thead><tr><th class&#61;"wid100">中介总公司名称</th><th class&#61;"wid100">业务区域</th><th class&#61;"wid100">中介总公司编码</th><th class&#61;"wid100">机构授权</th><th class&#61;"wid100">协议状态</th><th class&#61;"wid100">操作</th></tr></thead><tbody class&#61;"scrollstyle"><!-- ng-repeat&#61;"propo in list" --><tr ng-repeat&#61;"propo in selectEditList1"><td class&#61;"wid100 text_center">{{propo.PARTNERNAME}}</td><td class&#61;"wid100 text_center positionRelative">{{getAreaname(propo.AREANAME,index)}}<span class&#61;"positionAbsolute" ng-class&#61;"&#39;tri&#39;&#43;[$index]" ng-mouseover&#61;"mouseover()" ng-mouseout&#61;"mouseout()"><span ng-click&#61;"triangleShow(propo.AREANAME,$index)" ng-if&#61;"tri"&#43;$index>...详情</span>//弹框部分

//
//
×
//
//
{{triangle.code}}
//
//
//
//
弹框部分</span><span style&#61;"visibility:hidden;" ng-if&#61;"tri"&#43;index>...详情</span></td><td class&#61;"wid100 text_center">{{propo.COMPANY_CODE}}</td><td class&#61;"wid100 text_center">{{propo.ORGEMPOWER}}</td><td class&#61;"wid100 text_center">{{propo.AGREEMENTSTATUS}}</td><td class&#61;"wid100 text_center"><a class&#61;"btn btn-link btn-xs ng-binding ng-scope" ng-click&#61;"accreditDetials(propo,0)">授权管理</a></td></tr></tbody></table></div><tfoot><tr><td colspan&#61;"90%"><uib-pagination total-items&#61;"bigTotalItems2" ng-model&#61;"bigCurrentPage2" max-size&#61;"maxSize2" items-per-page&#61;"maxPage2"boundary-link-numbers&#61;"true" force-ellipses&#61;"true" previous-text&#61;"<" next-text&#61;">" ng-change&#61;"jumpToPage2()"class&#61;"pull-right"></uib-pagination></td></tr></tfoot></div></fieldset></div></div></div>//css/* 三角箭头 */<style>.triangle-down {width: 0;height: 0;border-left: 5px solid transparent;border-right: 5px solid transparent;border-top: 10px solid #000;position: absolute;top: -8px;right: 6px;}.positionAbsolute{position: absolute;}.triangleBox{position: absolute;width: 80px;height: 100px;background: #000;color: #fff;border-radius: 5px;top: -108px;right: -30px;}.close1{text-align: right;margin-right: 9px;cursor: pointer;}.triangleitem{overflow: auto;height: 100px;}//优化滚动条样式.scrollstyle ::-webkit-scrollbar{width:5px;}.scrollstyle ::-webkit-scrollbar-track{background-color:#000;}.scrollstyle ::-webkit-scrollbar-thumb{background-color:transparent;}
</style>

上边为html代码块&#xff0c;有一部分是代码注释。我也直接放上去了&#xff0c;方便大家看。注释的部分本来我是直接写上的&#xff0c;然后打算生成多个&#xff0c;然后想在点击时候判断显示用&#xff0c;但是后来呢&#xff0c;由于在写需求中3&#xff09;点击其他位置或者点击另一个详情的时候&#xff0c;取消这个弹框显示&#xff0c;如果是点击另一个详情&#xff0c;在另一个详情上方显示2&#xff09;的意思的时候呢&#xff0c;发现如果我这样写会出现更多问题。所以放弃了。将这部分代码写入了js动态生成了。

//详情显示与弹窗动态显示$scope.triangleShow &#61; function (areaname,index) {//由于我们需要在弹框的时候&#xff0c;判断是否有弹框存在&#xff0c;如果存在我们需要先隐藏弹框然后才能在你所点击的地方显示新的弹框if(document.getElementsByClassName(&#39;triangleshow&#39;)[0] !&#61; undefined){triangleHide(); }//动态创建弹框//在这里可能有人会质疑你怎么不用&#96;&#96;&#xff08;模板字符串&#xff09;拼接呢&#xff1f;多简单。&#xff08;这里不可以使用不支持&#xff0c;他会将你的模板字符串中的内容变成字符串输出&#xff09;所以只能动态生成了const div &#61; document.createElement(&#39;div&#39;);div.setAttribute(&#39;style&#39;, [&#39;position:absolute&#39;,&#39;left:-76px&#39;]);div.className &#61; &#39;triangleshow&#39;div.onmouseout &#61; function(){mouseout();}div.onmouseover &#61; function(){mouseover();}const div1 &#61; document.createElement(&#39;div&#39;);div1.className &#61;&#39;triangleBox&#39;;const div2 &#61; document.createElement(&#39;div&#39;);div2.innerHTML &#61; &#39;x&#39;;div2.className &#61; &#39;close1&#39;div2.onclick &#61; function(){triangleHide()}const div3 &#61; document.createElement(&#39;div&#39;);div3.className &#61; &#39;triangleitem&#39;const div4 &#61; document.createElement(&#39;div&#39;);div4.className &#61; &#39;triangle-down&#39;//arealist 使我们需要处理的数据&#xff0c;去掉前3个数据&#xff0c;将其与的数据进行显示var arealist &#61; [];arealist &#61; areaname.split(&#39;,&#39;);for(var i &#61;3;i<arealist.length;i&#43;&#43;){const div &#61; document.createElement(&#39;div&#39;);div.innerHTML &#61; arealist[i];div3.appendChild(div);}//这里我们没有append div2。这是一个关闭的小按钮&#xff08;类似于我们弹框中的x号&#xff09;&#xff0c;因为本需求不需要关闭按钮所以去掉了。// div1.appendChild(div2)div1.appendChild(div3)div.appendChild(div1)div.appendChild(div4)var tri &#61; &#39;tri&#39;&#43;index;document.getElementsByClassName(tri)[0].appendChild(div);}$scope.mouseplace &#61;true;$scope.mouseout &#61; function(){$scope.mouseplace &#61;true;}$scope.mouseover&#61;function (){$scope.mouseplace &#61;false;}//点击其他位置隐藏弹框的方法$scope.hidetriangle &#61; function($event){//mouseplace 这个字段呢&#xff0c;是我用来判断我点击其他地方的时候&#xff0c;如果鼠标的位置不在弹出框上&#xff0c;隐藏弹框&#xff0c;如果在&#xff0c;隐藏弹框的方法就不会执行if($scope.mouseplace && document.getElementsByClassName(&#39;triangleshow&#39;)[0] !&#61; undefined){document.getElementsByClassName(&#39;triangleshow&#39;)[0].parentNode.removeChild(document.getElementsByClassName(&#39;triangleshow&#39;)[0])}}//隐藏弹框方法function triangleHide(index){document.getElementsByClassName(&#39;triangleshow&#39;)[0].parentNode.removeChild(document.getElementsByClassName(&#39;triangleshow&#39;)[0])}//本方法为后端返回数据为“西北,内蒙古,华东地区,华南区域,华北区域”这样的字符串。我们需要自己判断是否显示详情$scope.getAreaname &#61; function(areaname,index){var arealist &#61; [];arealist &#61; areaname.split(&#39;,&#39;);if(arealist.length > 3){var tri &#61; &#39;tri&#39;&#43;index;$scope.tri &#61; true;return arealist[0]&#43;&#39;,&#39;&#43;arealist[1]&#43;&#39;,&#39;&#43;arealist[2];}else{var tri &#61; &#39;tri&#39;&#43;index;$scope.tri &#61; false;return areaname;}}

如果有更好的建议或者方法&#xff0c;欢迎留言☺


推荐阅读
  • JavaScript和HTML之间的交互是经由过程事宜完成的。事宜:文档或浏览器窗口中发作的一些特定的交互霎时。能够运用侦听器(或处置惩罚递次来预订事宜),以便事宜发作时实行相应的 ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • 本文总结了在编写JS代码时,不同浏览器间的兼容性差异,并提供了相应的解决方法。其中包括阻止默认事件的代码示例和猎取兄弟节点的函数。这些方法可以帮助开发者在不同浏览器上实现一致的功能。 ... [详细]
  • Java图形化计算器设计与实现
    本文介绍了使用Java编程语言设计和实现图形化计算器的方法。通过使用swing包和awt包中的组件,作者创建了一个具有按钮监听器和自定义界面尺寸和布局的计算器。文章还分享了在图形化界面设计中的一些心得体会。 ... [详细]
  • 本文分享了一个关于在C#中使用异步代码的问题,作者在控制台中运行时代码正常工作,但在Windows窗体中却无法正常工作。作者尝试搜索局域网上的主机,但在窗体中计数器没有减少。文章提供了相关的代码和解决思路。 ... [详细]
  • CSS3选择器的使用方法详解,提高Web开发效率和精准度
    本文详细介绍了CSS3新增的选择器方法,包括属性选择器的使用。通过CSS3选择器,可以提高Web开发的效率和精准度,使得查找元素更加方便和快捷。同时,本文还对属性选择器的各种用法进行了详细解释,并给出了相应的代码示例。通过学习本文,读者可以更好地掌握CSS3选择器的使用方法,提升自己的Web开发能力。 ... [详细]
  • android listview OnItemClickListener失效原因
    最近在做listview时发现OnItemClickListener失效的问题,经过查找发现是因为button的原因。不仅listitem中存在button会影响OnItemClickListener事件的失效,还会导致单击后listview每个item的背景改变,使得item中的所有有关焦点的事件都失效。本文给出了一个范例来说明这种情况,并提供了解决方法。 ... [详细]
  • 标题: ... [详细]
  • 前景:当UI一个查询条件为多项选择,或录入多个条件的时候,比如查询所有名称里面包含以下动态条件,需要模糊查询里面每一项时比如是这样一个数组条件:newstring[]{兴业银行, ... [详细]
  • 在Xamarin XAML语言中如何在页面级别构建ControlTemplate控件模板
    本文介绍了在Xamarin XAML语言中如何在页面级别构建ControlTemplate控件模板的方法和步骤,包括将ResourceDictionary添加到页面中以及在ResourceDictionary中实现模板的构建。通过本文的阅读,读者可以了解到在Xamarin XAML语言中构建控件模板的具体操作步骤和语法形式。 ... [详细]
  • This article discusses the efficiency of using char str[] and char *str and whether there is any reason to prefer one over the other. It explains the difference between the two and provides an example to illustrate their usage. ... [详细]
  • JS实现一键分享功能
    本文介绍了如何使用JS实现一键分享功能,并提供了2019独角兽企业招聘Python工程师的标准。同时,给出了分享到QQ空间、新浪微博和人人网的链接。 ... [详细]
  • 本文介绍了pack布局管理器在Perl/Tk中的使用方法及注意事项。通过调用pack()方法,可以控制部件在显示窗口中的位置和大小。同时,本文还提到了在使用pack布局管理器时,应注意将部件分组以便在水平和垂直方向上进行堆放。此外,还介绍了使用Frame部件或Toplevel部件来组织部件在窗口内的方法。最后,本文强调了在使用pack布局管理器时,应避免在中间切换到grid布局管理器,以免造成混乱。 ... [详细]
  • C#多线程解决界面卡死问题的完美解决方案
    当界面需要在程序运行中不断更新数据时,使用多线程可以解决界面卡死的问题。一个主线程创建界面,使用一个子线程执行程序并更新主界面,可以避免卡死现象。本文分享了一个例子,供大家参考。 ... [详细]
  • Android源码中的Builder模式及其作用
    本文主要解释了什么是Builder模式以及其作用,并结合Android源码来分析Builder模式的实现。Builder模式是将产品的设计、表示和构建进行分离,通过引入建造者角色,简化了构建复杂产品的流程,并且使得产品的构建可以灵活适应变化。使用Builder模式可以解决开发者需要关注产品表示和构建步骤的问题,并且当构建流程发生变化时,无需修改代码即可适配新的构建流程。 ... [详细]
author-avatar
sendymylove睛飘益
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有