- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
总的来说,我对 JS/JQuery 网络开发还很陌生。
对于一项工作任务,我被要求提出一个解决方案,其中显示列表中的前 3 个基金,如果他们投资超过 3 个,那么将有一个显示所有资金按钮,一旦点击它将切换剩余的资金。`
<!DOCTYPE html>
<html lang="en">
<head>
<title>Check your retirement plan demo</title>
<meta charset="UTF-8" />
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<link rel="stylesheet" type="text/css" href="css/dropdown-component.css" />
<script src="js/modernizr.custom.63321.js"></script>
</head>
<body style="background-color:#eaeaea;">
<div class="container">
<h2> Dropdown Component</h2>
<!-- THIS BIT FUNDS START -->
<section class="main clearfix">
<select id="cd-dropdown" name="cd-dropdown" class="cd-select">
<option value="-1" selected>Funds in your portfolio (3)</option>
<option value="1">fund1 £60,000</option>
<option value="2">fund 2 £40,000</option>
<option value="3">fund 3 £24,000</option>
<option value="4">View all funds ></option>
<option value="5">Fund 5 £40,000</option>
</select>
</section>
<!-- THIS BIT FUNDS END -->
</div>
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.8.3/jquery.min.js"></script>
<script type="text/javascript" src="js/jquery.dropdown.js"></script>
<script type="text/javascript">
$(function () {
$('#cd-dropdown').dropdown({
gutter: 5
});
});
</script>
</body>
</html>`
我正在使用 jquery 下拉解决方案来帮助我处理资金,它没有隐藏大于 3 的资金并在单击查看更多资金后切换它们的功能。
/**
* jquery.dropdown.js v1.0.0
* http://www.codrops.com
*
* Licensed under the MIT license.
* http://www.opensource.org/licenses/mit-license.php
*
* Copyright 2012, Codrops
* http://www.codrops.com
*/
; (function ($, window, undefined) {
'use strict';
$.DropDown = function (options, element) {
this.$el = $(element);
this._init(options);
};
// the options
$.DropDown.defaults = {
speed: 300,
easing: 'ease',
gutter: 0,
// initial stack effect
stack: true,
// delay between each option animation
delay: 0,
// random angle and positions for the options
random: false,
// rotated [right||left||false] : the options will be rotated to thr right side or left side.
// make sure to tune the transform origin in the stylesheet
rotated: false,
// effect to slide in the options. value is the margin to start with
slidingIn: false,
onOptionSelect: function (opt) { return false; }
};
$.DropDown.prototype = {
_init: function (options) {
// options
this.options = $.extend(true, {}, $.DropDown.defaults, options);
this._layout();
this._initEvents();
},
_layout: function () {
var self = this;
this.minZIndex = 1000;
var value = this._transformSelect();
this.opts = this.listopts.children('li');
this.optsCount = this.opts.length;
this.size = { width: this.dd.width(), height: this.dd.height() };
var elName = this.$el.attr('name'), elId = this.$el.attr('id'),
inputName = elName !== undefined ? elName : elId !== undefined ? elId : 'cd-dropdown-' + (new Date()).getTime();
this.inputEl = $('<input type="hidden" name="' + inputName + '" value="' + value + '"></input>').insertAfter(this.selectlabel);
this.selectlabel.css('z-index', this.minZIndex + this.optsCount);
this._positionOpts();
if (Modernizr.csstransitions) {
setTimeout(function () { self.opts.css('transition', 'all ' + self.options.speed + 'ms ' + self.options.easing); }, 25);
}
},
_transformSelect: function () {
var optshtml = '', selectlabel = '', value = -1;
this.$el.children('option').each(function () {
var $this = $(this),
val = isNaN($this.attr('value')) ? $this.attr('value') : Number($this.attr('value')),
classes = $this.attr('class'),
selected = $this.attr('selected'),
label = $this.text();
if (val !== -1) {
optshtml +=
classes !== undefined ?
'<li data-value="' + val + '"id=fundID' + val + '><span class="' + classes + '">' + label + '</span></li>' :
'<li data-value="' + val + '"id=fundID' + val + '><span>' + label + '</span></li>';
}
if (val > 3) {}
if (selected) {
selectlabel = label;
value = val;
}
});
this.listopts = $('<ul/>').append(optshtml);
this.selectlabel = $('<span/>').append(selectlabel);
this.dd = $('<div class="cd-dropdown"/>').append(this.selectlabel, this.listopts).insertAfter(this.$el);
this.$el.remove();
return value;
},
_positionOpts: function (anim) {
var self = this;
this.listopts.css('height', 'auto');
this.opts
.each(function (i) {
$(this).css({
zIndex: self.minZIndex + self.optsCount - 1 - i,
top: self.options.slidingIn ? (i + 1) * (self.size.height + self.options.gutter) : 0,
left: 0,
marginLeft: self.options.slidingIn ? i % 2 === 0 ? self.options.slidingIn : - self.options.slidingIn : 0,
opacity: self.options.slidingIn ? 0 : 1,
transform: 'none'
});
});
if (!this.options.slidingIn) {
this.opts
.eq(this.optsCount - 1)
.css({ top: this.options.stack ? 9 : 0, left: this.options.stack ? 4 : 0, width: this.options.stack ? this.size.width - 8 : this.size.width, transform: 'none' })
.end()
.eq(this.optsCount - 2)
.css({ top: this.options.stack ? 6 : 0, left: this.options.stack ? 2 : 0, width: this.options.stack ? this.size.width - 4 : this.size.width, transform: 'none' })
.end()
.eq(this.optsCount - 3)
.css({ top: this.options.stack ? 3 : 0, left: 0, transform: 'none' });
}
},
_initEvents: function () {
var self = this;
this.selectlabel.on('mousedown.dropdown', function (event) {
self.opened ? self.close() : self.open();
return false;
});
this.opts.on('click.dropdown', function () {
if (self.opened) {
var opt = $(this);
self.options.onOptionSelect(opt);
self.inputEl.val(opt.data('value'));
self.selectlabel.html(opt.html());
self.close();
}
});
},
open: function () {
var self = this;
this.dd.toggleClass('cd-active');
this.listopts.css('height', (this.optsCount + 1) * (this.size.height + this.options.gutter));
this.opts.each(function (i) {
$(this).css({
opacity: 1,
top: self.options.rotated ? self.size.height + self.options.gutter : (i + 1) * (self.size.height + self.options.gutter),
left: self.options.random ? Math.floor(Math.random() * 11 - 5) : 0,
width: self.size.width,
marginLeft: 0,
transform: self.options.random ?
'rotate(' + Math.floor(Math.random() * 11 - 5) + 'deg)' :
self.options.rotated ?
self.options.rotated === 'right' ?
'rotate(-' + (i * 5) + 'deg)' :
'rotate(' + (i * 5) + 'deg)'
: 'none',
transitionDelay: self.options.delay && Modernizr.csstransitions ? self.options.slidingIn ? (i * self.options.delay) + 'ms' : ((self.optsCount - 1 - i) * self.options.delay) + 'ms' : 0
});
});
this.opened = true;
},
close: function () {
var self = this;
this.dd.toggleClass('cd-active');
if (this.options.delay && Modernizr.csstransitions) {
this.opts.each(function (i) {
$(this).css({ 'transition-delay': self.options.slidingIn ? ((self.optsCount - 1 - i) * self.options.delay) + 'ms' : (i * self.options.delay) + 'ms' });
});
}
this._positionOpts(true);
this.opened = false;
}
}
$.fn.dropdown = function (options) {
var instance = $.data(this, 'dropdown');
if (typeof options === 'string') {
var args = Array.prototype.slice.call(arguments, 1);
this.each(function () {
instance[options].apply(instance, args);
});
}
else {
this.each(function () {
instance ? instance._init() : instance = $.data(this, 'dropdown', new $.DropDown(options, this));
});
}
return instance;
};
})(jQuery, window);'
任何人都可以帮助我想出一个快速的解决方案或指出正确的方向吗?谢谢
最佳答案
您想在页面上创建一个隐藏元素来缓存或容纳您不希望可见的选项。然后,您将向该元素添加一些 CSS,并使用 jQuery 将选项放入其中。
HTML
<select id="cd-dropdown" name="cd-dropdown" class="cd-select">
<option value="-1" selected>Funds in your portfolio (3)</option>
<option value="1">fund1 £60,000</option>
<option value="2">fund 2 £40,000</option>
<option value="3">fund 3 £24,000</option>
<option value="4">View all funds ></option>
<option value="5">Fund 5 £40,000</option>
</select>
<input type="button" value="View all" class='view_more_button' />
<input type="button" value="View less" class='view_less_button hide' />
CSS
.hide {
left: -9999px !important;
position: absolute !important;
visibility: hidden;
z-index: -500;
top: -9999px;
}
JavaScript
//Create on DOM element dynamically that will house options greater than three.
var blank_input = $('<select>', {
class: 'hidden_input_field hide',
name: 'hidden_fields'
});
//This variable caches the master select element.
var master_select_menu = jQuery('#cd-dropdown');
//Put the blank select field in the DOM tree to be select via jQuery selectors.
blank_input.appendTo(jQuery('body'));
jQuery('.view_more_button').on('click', function(e) {
var place_holder_select_field = jQuery('.hidden_input_field');
if (place_holder_select_field.children('option').length) {
jQuery('.moved').each(function(index,element) {
jQuery(element).appendTo(master_select_menu);
});
jQuery(e.target).addClass('hide');
jQuery('.view_less_button').removeClass('hide');
}
master_select_menu.val(-1).change();
});
jQuery('.view_less_button').on('click', function(e) {
view_three();
jQuery(e.target).addClass('hide');
jQuery('.view_more_button').removeClass('hide');
master_select_menu.val(-1).change();
});
view_three();
//This function gets called as soon as the page loads, where it appends any option element greater than 3 to the hidden select field.
function view_three() {
jQuery('option').each(function(index, element) {
var place_holder_select_field = jQuery('.hidden_input_field');
if (index > 3) {
jQuery(element).addClass('moved').appendTo(place_holder_select_field);
}
});
}
//Create on DOM element dynamically that will house options greater than three.
var blank_input = $('<select>', {
class: 'hidden_input_field hide',
name: 'hidden_fields'
});
//This variable caches the master select element.
var master_select_menu = jQuery('#cd-dropdown');
//Put the blank select field in the DOM tree to be select via jQuery selectors.
blank_input.appendTo(jQuery('body'));
jQuery('.view_more_button').on('click', function(e) {
var place_holder_select_field = jQuery('.hidden_input_field');
if (place_holder_select_field.children('option').length) {
jQuery('.moved').each(function(index,element) {
jQuery(element).appendTo(master_select_menu);
});
jQuery(e.target).addClass('hide');
jQuery('.view_less_button').removeClass('hide');
}
master_select_menu.val(-1).change();
});
jQuery('.view_less_button').on('click', function(e) {
view_three();
jQuery(e.target).addClass('hide');
jQuery('.view_more_button').removeClass('hide');
master_select_menu.val(-1).change();
});
view_three();
//This function gets called as soon as the page loads, where it appends any option element greater than 3 to the hidden select field.
function view_three() {
jQuery('option').each(function(index, element) {
var place_holder_select_field = jQuery('.hidden_input_field');
if (index > 3) {
jQuery(element).addClass('moved').appendTo(place_holder_select_field);
}
});
}
.hide {
left: -9999px !important;
position: absolute !important;
visibility: hidden;
z-index: -500;
top: -9999px;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
<select id="cd-dropdown" name="cd-dropdown" class="cd-select">
<option value="-1" selected>Funds in your portfolio (3)</option>
<option value="1">fund1 £60,000</option>
<option value="2">fund 2 £40,000</option>
<option value="3">fund 3 £24,000</option>
<option value="4">View all funds ></option>
<option value="5">Fund 5 £40,000</option>
</select>
<input type="button" value="View all" class='view_more_button' />
<input type="button" value="View less" class='view_less_button hide' />
关于javascript - 我想在下拉列表中创建一个 "See all your funds"按钮,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45153233/
这是一组有毒的表情包,原因很简单,会给人洗脑的节奏啊!不要问小编怎么知道,因为现在思维已经混乱了。好吧,对于小伙伴们来说。可能这些表情包并不算啥。但是有一点不可否认,确实具有洗脑能力。  
大约 14 小时前,我将 GA 添加到我的网站,并且一直在使用不同的平台和 IP 访问该网站。仍然没有看到为 session 填充的任何数据,或为 GA 中的“受众”选项卡填充的任何数据。但是当我在连
so basically I am trying to make it so if the dynamically generated description has over 5 lines
so basically I am trying to make it so if the dynamically generated description has over 5 lines
我正在用 Cucumber 在 Rails 中测试一个场景,它返回说它找不到要单击的编辑链接。如果我自己去页面,它就在那里。显然我做错了什么,但我看不到。 如果我在我的场景之前添加 @selenium
这个问题在这里已经有了答案: What does the number in parentheses shown after Unix command names in manpages mean?
这个问题在这里已经有了答案: What does the number in parentheses shown after Unix command names in manpages mean?
我创建了一个简单的测试来验证特定站点中面包屑的出现次数是否为 2: 站点是:https://theculturetrip.com/europe/united-kingdom/england/londo
好的,这使我无法忍受,真是太复杂了…… 因此,要达到主题的目的,而又不授予用户对所有存储桶中所有文件的读取权限(proj中的其他存储桶都具有敏感数据) 我导航到存储桶->权限,并将用户添加为Stora
我创建了一个简单的 DirectX 应用程序来渲染一个顶点场。顶点呈现如下(如果从顶部查看): |\|\|\|\| |\|\|\|\| 每个三角形都是这样渲染的: 1 |\ 2 3 这应该意味着多边形
我正在 Clojure 中尝试 eval: (let [code_as_data '(if (< sequ) on_true on_false) sequ [1 3 5] on
嗯,我正在使用 BlueJ。我知道我肯定可以离线使用它们。但是在没有 Internet 连接的情况下是否可以查看 Oracle 文档呢?包括方法摘要和说明。类似这样但离线的东西 http://docs
我正在 Clojure 中尝试 eval: (let [code_as_data '(if (< sequ) on_true on_false) sequ [1 3 5] on
我有一个生成如下订单列表的查询: Invoice Description Qty Amount VAT VAT code 3761 Flyers
在 Xcode 中,我怎样才能像这张图片那样制作“透视”效果: 就像文本是覆盖颜色中的一个洞一样。我需要以编程方式执行此操作以显示不同的文本。 最佳答案 CGImages 可以有一个单独的图像蒙版,它
查看 C++ 标准( current draft http://isocpp.org/files/papers/N3690.pdf,sec 20.8.3 就是这样一个地方)和 LLVM 的 libc+
我按照本教程在我的 CentOS 5.5 上安装了 python2.7: http://villaroad.com/2010/10/rolling-python-2-6-2-on-centos-5-3
我想使用注释 block 中的@see 链接另一个对象的方法 @see 只给了我链接类的选项,而不是方法。 什么是黑客? public class A { B bee; /** * Ju
fa <- function(x){x+1} fb <- function(x){x-1} f1 <- function(x, y){f(x)^y} f2 <- function(x, ab, y){
我创建了一个脚本来使用请求登录到linkedin。剧本做得很好。 登录后,我使用了这个网址 https://www.linkedin.com/groups/137920/刮掉这个名字 Marketin
我是一名优秀的程序员,十分优秀!