- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我一直在使用 select2 作为我选择的网站 UI。但是,我注意到有一个用于 select2 的特性,我觉得应该用于我的文本框;清除所有功能。
http://ivaynberg.github.io/select2/
我在网络上看到了很多关于如何将清除按钮添加到文本框元素的帖子,但似乎没有一个符合我的兴趣。因为我正在使用 select2,所以我希望我的输入框具有与我的 select2 相同的外观和感觉,包括“清除按钮”。
我能找到的最接近的功能控件位于此处:Clearing Search terms from input field. ,他给出了 demo found here.
这样做有两个缺点:
如果有人知道任何解决方案,那将是一个很好的帮助
最佳答案
这是我想出的解决方案:
请检查代码,看看是否可以进行任何调整。我使用的是 jquery,但决定将其作为 angular js 指令,因为它完全是 UI,与数据本身无关。
我从 html 开始:
<div clear-text>
<input ng-model="CustomerName" type="text" name="" value="" placeholder="Name" />
</div>
请注意,我的输入框周围必须有一个 div。为了让我的 X 出现,你需要有一个包装器。你会看到当我包含我的 css 时会发生什么:
.clearable{
display: inline-block;
*display: inline;
zoom: 1;
height:30px;
}
.clearable input
{
float: left;
background: transparent;
cursor:pointer;
}
.clearable.x{
background: transparent url(../themes/base/images/clearText-dark.png) no-repeat 95% center;
}
.clearable.onX{
background: transparent url(../themes/base/images/clearText-light.png) no-repeat 95% center;
}
要点是获得一个输入框,使面部皮肤透明,并让 div 处理图像的显示方式。棘手的部分是实际功能。
这是我的 Angular Directive(指令):
app.directive('clearText', function () {
var directiveDefinitionObject = {
link: function link(scope, element, attrs) {
element.addClass("clearable");
function tog(v) { return v ? 'addClass' : 'removeClass'; }
element.keyup(function () {
element[tog(element.children('input[type=text]:only-child').val())]('x');
}).mousemove(function (e) {
e.preventDefault();
if (element.hasClass('x')) {
element[tog(((this.offsetWidth - 30) < (e.clientX - this.getBoundingClientRect().left)) &&
((this.offsetWidth - 5) > (e.clientX - this.getBoundingClientRect().left)) &&
((this.offsetHeight - 30) < (e.clientY - this.getBoundingClientRect().top)) &&
((this.offsetHeight - 5) > (e.clientY - this.getBoundingClientRect().top)))]('onX');
}
}).click( function (e) {
e.preventDefault();
if (element.hasClass('onX')) {
element.removeClass('x onX');
element.children('input[type=text]:only-child').val('');
}
});
}
};
return (directiveDefinitionObject);
}]);
我想指出几件事。我拒绝在 $document 上做,因为我希望每个元素都相互隔离。所以如果你制作多个文本框,这不会影响另一个。其次,mousemove 用于创建一个小“窗口”,允许 X 的颜色在鼠标悬停在其上时发生变化。
这是 jsfiddle:http://jsfiddle.net/8T27H/2/
在ie7、ie8、ie9、chrome、操作、firefox上测试
关于jquery - 输入文本框 : mimic "clear text" X button just like select2 dropdown component,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21468669/
我正在尝试让 Bootstrap 下拉菜单与我的 Jade 布局一起使用。但实际上,当我尝试在我的 Jade 文件中执行 $(".dropdown-toggle").dropdown 时出现此错误:
我正在使用 Semantic React UI's Dropdown ,并且我希望它在其父组件安装后立即获得焦点:用户应该能够立即搜索。 我尝试在父级的 render() 中使用 ref: (thi
我有一个脚本如下: var i = 0; function add_relation() { i = i + 1; var key = $('', {
我在 MVC 中有 2 个 DropDowns 并尝试使用 AngularJS。我的第一个 DropDown 填充了正确来自数据库的数据。当用户在第一个 DropDown 上进行选择时,第二个 Dro
我是一名开发新手,但我偶然发现了一个我无法解决的案例。我将 ASP.NET MVC 与 C# 以及一些 javascript(JQuery、JSON...)结合使用。 我要做的是根据在 other 中
在 Bootstrap 文档中,似乎有两种不同的方法来创建下拉列表: .dropdown .btn-group first如下: Dropdown ...
我确实在 kv 文件中定义了一个基本的自定义 DropDown。应用程序 GUI 非常简单,顶部有一个按钮栏,屏幕的其余部分有一个 TextInput。这是代码: dropdowntrialgui.p
在移动 View 中单击 .dropdown 菜单时,.dropdown 和 .dropdown-menu 之间有一个小空间. 如图所示 Question is it possible to remo
我正在尝试创建一个类似于 DataEntry 网格/表的结构,其中用户在单击按钮时追加新行。该行将包含文本框、下拉菜单、日历控件。所有这些都应该在客户端完成。到目前为止,我已经有了这个,正如你所看到的
我有一个带有使用 ul 和 li ( jsfiddle ) 的下拉列表的 jsfiddle。尝试将其转换为选择选项下拉列表时,我没有得到相同的选项 ([jsfiddle]) 2 .我猜这与我重命名某个
我正在使用@atlaskit/dropdown-menu (https://atlaskit.atlassian.com/packages/core/dropdown-menu)。我想在 Item 点
我在我的 angular 应用程序中使用 PrimeNG,我有 p-dropdown 的问题 问题 我为 country 和 caste_category 有两个下拉菜单,我只为 India 提供 c
我有一个表单 View ,在编辑模板中我有两个下拉菜单。 下拉 1 明确设置了允许值的列表。它也设置为自动回发。 下拉 2 是数据绑定(bind)到 objectdatasource,这个 objec
我有一个名为 Agency 的下拉菜单,其中包含 2 个选项: 文凭 PPS 如果选择 SPM,则不会出现下拉菜单。但是,如果选择 PPS,则会出现另外 2 个名为 Department 和 Offi
我是 Angular 的新手,所以这可能是一个非常简单的问题。我正在使用 ngx-select-dropdown (下拉控件)。页面上有两个下拉控件,当第一个下拉列表更改时,第二个下拉列表应更新下拉选
我有一个包含文本区域的下拉菜单。当在文本区域按下返回键时,我希望关闭下拉菜单。这是以下内容的作用: $(document).ready(function(){ $('#edit').keypres
我的页面中有这些SELECT Pending Confirmed Cancelled Refunded Shipped Paid Complete 还有这个 Pending Confirme
我有兴趣学习以智能、优雅的方式在整个站点中构建导航项,这些导航项具有胡萝卜,单击后会展开菜单项列表。 我希望动态构建菜单项(不一定全部使用 ajax)。但它们不应在页面上进行硬编码。 这似乎是像 TW
我有一个选择下拉菜单,一个是 Bootstrap 导航下拉菜单,而不是单击以打开 Bootstrap 导航下拉菜单我在鼠标悬停时更改了它但是当选择下拉菜单打开并且鼠标悬停在 Bootstrap 导航上
我对此很陌生,所以如果我的问题没有按应有的方式提出,我深表歉意。 基本上,我使用 jQuery 的目的是,当从第一个下拉框中选择名为“Apple”的字段时,第二个下拉框将只允许选择“Firm”字段,而
我是一名优秀的程序员,十分优秀!