- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
有人可以帮助我使用 CSS(less)吗,因为我似乎还不能理解它是如何工作的,我已经通过 node.js 安装了它,但现在如何将它链接到我的代码/网页?
由于某种原因,选择框没有输出到网页上,因为很可能我需要将较少的文件添加到目录中(如果我错了请纠正我)但我不知道我需要从哪个位置或从哪里添加添加它们。
<head>
<script src="//cdnjs.cloudflare.com/ajax/libs/less.js/3.7.1/less.min.js" ></script>
</head>
<div class="container">
<div id="select" ng-model=""></div>
</div>
<style>
@import url('https://fonts.googleapis.com/css?family=Roboto:400,100,300,700,900');
@import url('//netdna.bootstrapcdn.com/font-awesome/4.0.3/css/font-awesome.min.css');
body {
font-family: 'Roboto';
padding: 0;
margin: 0;
background: linear-gradient(-45deg, #183850 0, #183850 25%, #192c46 50%, #22254c 75%, #22254c 100%);
background-repeat: no-repeat;
background-attachment: fixed;
margin-top: 100px;
margin-left: 20px;
color: #ecf0f1;
}
.container {
margin: 0 auto;
display: table;
}
/* selecionator */
.selectionator {
position: relative;
border-radius: 2px;
background-color: #2c3e50;
color: #95a5a6;
perspective: 800px;
width: 200px;
/*
&:before {
content: "";
background-color: transparent;
width: 100%;
height: 2.5em;
position: absolute;
background-image: linear-gradient(top, #000, rgba(0,0,0,0));
}
*/
.search {
position: relative;
display: block;
border: 0px;
width: 100%;
padding: 1em;
outline: none;
color: #FFF;
background-color: #16a085;
box-sizing: border-box;
transform-style: preserve-3d;
transform-origin: 50% 0%;
transition: transform .3s;
border-radius: 2px;
z-index: 99;
.overlay {
width: 100%;
background-color: #f00;
height: 100%;
position: absolute;
left: 0;
top: 0px;
background: linear-gradient(to bottom, rgba(0, 0, 0, 0.35) 0%, rgba(0, 0, 0, 0.1) 100%);
opacity: 0;
}
.shadow {
position: absolute;
height: 15px;
width: 100%;
left: 0;
bottom: -15px;
transform-origin: center bottom;
transform: scale(0.95, 1) translate3d(0, 0px, 0);
background: linear-gradient(to bottom, rgba(0, 0, 0, 0.75) 0%, rgba(0, 0, 0, 0) 100%);
opacity: 0;
}
&:before {
content: "\f078";
display: inline-block;
font-family: FontAwesome;
font-style: normal;
font-weight: normal;
line-height: 1.5;
float: right;
vertical-align: middle;
}
}
&:hover, &.opened {
.search {
transform: rotate3d(1,0,0,60deg);
.overlay, .shadow {
opacity: 1;
}
}
.menu {
height: 200px;
opacity: 1;
}
}
.menu {
overflow: hidden;
position: absolute;
width: 100%;
top: 50%;
height: 0px;
border-radius: 0px;
background-color: #2c3e50;
transition: all 0.3s ease;
opacity: 0;
border: 1px solid #16a085;
border-top: none;
}
ul.list {
list-style: none;
padding: 0px;
margin: 0px;
overflow:hidden;
overflow-y: scroll;
height: 0px;
backface-visibility: hidden;
transition: all 0.3s ease;
opacity: 0.75;
width: 100%;
height: 100%;
> li span.header {
display: block;
padding: 6px;
background-color: #34495e;
font-weight: 200;
color: #fff;
}
}
ul.optgroup {
list-style: none;
padding: 0px;
margin: 0px;
-webkit-touch-callout: none;
-webkit-user-select: none;
-moz-user-select: none;
user-select: none;
li {
&:hover {
background-color: #16a085;
color: #fff;
}
input[type="checkbox"] {
display: none;
margin: 6px;
&:checked {
background-color: #1abc9c;
~ label {
background-color: #2980b9;
color: #fff;
&:before {
content: "\f14a";
}
}
}
}
label {
font-weight: 100;
display: block;
//margin: 0px 0px 0px 15px;
padding-left: 15px;
line-height: 2em;
transition: all 0.3s ease;
&:before {
content: "\f096";
display: inline-block;
font-family: FontAwesome;
font-style: normal;
font-weight: normal;
line-height: 1;
margin-right: 8px;
vertical-align: middle;
}
}
}
}
}
</style>
<script>
/*
* library dependencies:
* jquery
*/
// plugin 1.0
$(document).ready(function () {
"use strict";
var pluginName = "selectionator";
var defaults = {
propertyName: "selectionator",
src: null,
orgElement: null,
checkedItems: [],
// custom callback events
onError: function(error) {}
};
function Plugin(element, options) {
this.element = element;
this.selector = null;
this.options = $.extend({}, defaults, options);
this._defaults = defaults;
this._name = pluginName;
this.init();
}
Plugin.prototype = {
init: function () {
console.log("options: ", this.options);
var that = this;
var self = $(that.element);
that.options.src = that.element.getAttribute('data-src');
that.selector = that.createFromJson(that.options.data);
that.options.orgElement = that.element.parentNode.replaceChild(that.selector, that.element);
$(that.selector).addClass(that._name);
},
createFromJson: function(options) {
var that = this;
var select = document.createElement('select');
var popup = document.createElement('div');
var header = document.createElement('div');
var search = document.createElement('span');
var overlay = document.createElement('span');
overlay.className = 'overlay';
var shadow = document.createElement('span');
shadow.className = 'shadow';
var placeholder = document.createTextNode('Options');
search.className = 'search';
search.appendChild(shadow);
search.appendChild(overlay);
search.appendChild(placeholder);
popup.appendChild(search);
var menu = document.createElement('ul');
select.style.display = 'none';
menu.className = 'list';
var box = document.createElement('div');
box.className = 'menu';
box.appendChild(menu);
popup.appendChild(box);
console.log("optgroup", options.optgroups);
options.optgroups.forEach(function(optgroup, index) {
var menuItem = document.createElement('li');
//menuItem.className('header');
var header = document.createElement('span');
header.className = 'header';
var caption = document.createTextNode(optgroup.label);
header.appendChild(caption);
menuItem.appendChild(header);
var menuItems = document.createElement('ul');
menuItems.className = 'optgroup';
menuItem.appendChild(menuItems);
menu.appendChild(menuItem);
optgroup.options.forEach(function(option, index) {
var opt = new Option(option.text, option.value, option.defaultSelected, option.selected);
select.options.add(opt);
var item = document.createElement('li');
var label = document.createElement('label');
label.setAttribute("for", option.value);
var checkbox = document.createElement('input');
$(checkbox).data(option);
checkbox.setAttribute('type', 'checkbox');
checkbox.addEventListener('change', function(event){
var checkbox = event.target;
var $el = $(event.srcElement);
if (checkbox.checked) {
that.options.checkedItems.push(event.srcElement);
placeholder.nodeValue = "Selected: " + that.options.checkedItems.length + " out of " + $(that.selector).find('input[type="checkbox"]').length;
} else {
that.options.checkedItems.pop();
that.options.checkedItems = that.options.checkedItems.filter(function(items, index){
return items.value != $el.data().value;
});
placeholder.nodeValue = "Selected: " + that.options.checkedItems.length + " out of " + $(that.selector).find('input[type="checkbox"]').length;
}
console.log("data: ", that.options.checkedItems);
});
checkbox.id = option.value;
var caption = document.createTextNode(option.text);
label.appendChild(caption);
item.appendChild(checkbox);
item.appendChild(label);
menuItems.appendChild(item);
});
});
return popup;
},
onAddFriend: function(data) {
var that = this;
return that.options.onAddFriend(that, data);
},
onRemoveFriend: function(data){
var that = this;
var self = $(that.element);
return that.options.onRemoveFriend(data);
},
destroy: function() {
var that = this;
$(that.element).unbind("destroyed", that.teardown);
that.teardown();
},
teardown: function() {
var that = this;
$(that.element).removeClass(that._name);
$(that.selector).replaceWith(that.options.orgElement);
$(that.element).removeData(that._name);
that.unbind();
that.element = null;
},
bind: function() { },
unbind: function() { }
};
$.fn[pluginName] = function (options) {
return this.each(function () {
if (!$.data(this, pluginName)) {
$.data(this, pluginName, new Plugin(this, options));
}
});
};
});
//Attach plugin to all matching element
$(document).ready(function () {
$('#select').selectionator({
data: {
optgroups: [{
label: 'Marketing',
options: [{
value: 0,
text: 'Steve',
defaultSelected: true,
selected: false
}, {
value: 345,
text: 'mike',
defaultSelected: false,
selected: false
}, {
value: 111,
text: "pepe",
defaultSelected: false,
selected: false
}, {
value: 433,
text: "anna",
defaultSelected: false,
selected: true
}]
}, {
label: 'Sales',
options: [{
value: 555,
text: 'linda',
defaultSelected: false,
selected: false
}, {
value: 333,
text: "mike",
defaultSelected: false,
selected: false
}]
}]
}
});
setTimeout(function(){
$(".selectionator").addClass('opened');
}, 500);
setTimeout(function(){
$(".selectionator").removeClass('opened');
}, 1250);
});
</script>
最佳答案
像这样创建元素结构
风格(文件夹)
将 less 代码复制到 style.less 中
然后运行lessc styles.less styles.css
来自 less.org
将其编译成style.css
关于javascript - 如何使用 CSS(较少),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52910575/
我在网上搜索但没有找到任何合适的文章解释如何使用 javascript 使用 WCF 服务,尤其是 WebScriptEndpoint。 任何人都可以对此给出任何指导吗? 谢谢 最佳答案 这是一篇关于
我正在编写一个将运行 Linux 命令的 C 程序,例如: cat/etc/passwd | grep 列表 |剪切-c 1-5 我没有任何结果 *这里 parent 等待第一个 child (chi
所以我正在尝试处理文件上传,然后将该文件作为二进制文件存储到数据库中。在我存储它之后,我尝试在给定的 URL 上提供文件。我似乎找不到适合这里的方法。我需要使用数据库,因为我使用 Google 应用引
我正在尝试制作一个宏,将下面的公式添加到单元格中,然后将其拖到整个列中并在 H 列中复制相同的公式 我想在 F 和 H 列中输入公式的数据 Range("F1").formula = "=IF(ISE
问题类似于this one ,但我想使用 OperatorPrecedenceParser 解析带有函数应用程序的表达式在 FParsec . 这是我的 AST: type Expression =
我想通过使用 sequelize 和 node.js 将这个查询更改为代码取决于在哪里 select COUNT(gender) as genderCount from customers where
我正在使用GNU bash,版本5.0.3(1)-发行版(x86_64-pc-linux-gnu),我想知道为什么简单的赋值语句会出现语法错误: #/bin/bash var1=/tmp
这里,为什么我的代码在 IE 中不起作用。我的代码适用于所有浏览器。没有问题。但是当我在 IE 上运行我的项目时,它发现错误。 而且我的 jquery 类和 insertadjacentHTMl 也不
我正在尝试更改标签的innerHTML。我无权访问该表单,因此无法编辑 HTML。标签具有的唯一标识符是“for”属性。 这是输入和标签的结构:
我有一个页面,我可以在其中返回用户帖子,可以使用一些 jquery 代码对这些帖子进行即时评论,在发布新评论后,我在帖子下插入新评论以及删除 按钮。问题是 Delete 按钮在新插入的元素上不起作用,
我有一个大约有 20 列的“管道分隔”文件。我只想使用 sha1sum 散列第一列,它是一个数字,如帐号,并按原样返回其余列。 使用 awk 或 sed 执行此操作的最佳方法是什么? Accounti
我需要将以下内容插入到我的表中...我的用户表有五列 id、用户名、密码、名称、条目。 (我还没有提交任何东西到条目中,我稍后会使用 php 来做)但由于某种原因我不断收到这个错误:#1054 - U
所以我试图有一个输入字段,我可以在其中输入任何字符,但然后将输入的值小写,删除任何非字母数字字符,留下“。”而不是空格。 例如,如果我输入: 地球的 70% 是水,-!*#$^^ & 30% 土地 输
我正在尝试做一些我认为非常简单的事情,但出于某种原因我没有得到想要的结果?我是 javascript 的新手,但对 java 有经验,所以我相信我没有使用某种正确的规则。 这是一个获取输入值、检查选择
我想使用 angularjs 从 mysql 数据库加载数据。 这就是应用程序的工作原理;用户登录,他们的用户名存储在 cookie 中。该用户名显示在主页上 我想获取这个值并通过 angularjs
我正在使用 autoLayout,我想在 UITableViewCell 上放置一个 UIlabel,它应该始终位于单元格的右侧和右侧的中心。 这就是我想要实现的目标 所以在这里你可以看到我正在谈论的
我需要与 MySql 等效的 elasticsearch 查询。我的 sql 查询: SELECT DISTINCT t.product_id AS id FROM tbl_sup_price t
我正在实现代码以使用 JSON。 func setup() { if let flickrURL = NSURL(string: "https://api.flickr.com/
我尝试使用for循环声明变量,然后测试cols和rols是否相同。如果是,它将运行递归函数。但是,我在 javascript 中执行 do 时遇到问题。有人可以帮忙吗? 现在,在比较 col.1 和
我举了一个我正在处理的问题的简短示例。 HTML代码: 1 2 3 CSS 代码: .BB a:hover{ color: #000; } .BB > li:after {
我是一名优秀的程序员,十分优秀!