小编Meg*_*att的帖子

CSS:将宽度/高度设置为百分比减去像素

我已经在其他几个背景下看过这个问题了,但我认为值得再次询问我的具体案例.我正在尝试创建一些可重用的CSS类,以便在我的网站上实现更高的一致性和更少的混乱,而且我一直试图标准化我经常使用的一件事.

我有一个容器div,我不想设置它的高度(因为它会根据网站的位置而有所不同),里面是一个标题div,然后是一个无序的项目列表,所有这些都是CSS适用于他们.看起来很像这样:

窗口小部件

我希望无序列表占用容器div中剩余的空间,知道标题div是18px高.我只是不知道如何将列表的高度指定为"100%减去18px的结果".有没有人在这种情况下有任何建议?

css height pixel

455
推荐指数
7
解决办法
37万
查看次数

使用.text()仅检索未嵌套在子标记中的文本

如果我有这样的HTML:

<li id="listItem">
    This is some text
    <span id="firstSpan">First span text</span>
    <span id="secondSpan">Second span text</span>
</li>
Run Code Online (Sandbox Code Playgroud)

我正在尝试使用.text()只检索字符串"这是一些文本",但如果我要说$('#list-item').text(),我得到"这是一些textFirst span text secondSecond span text".

有没有办法获得(并可能通过类似的东西.text(""))只是标签内的自由文本,而不是其子标签中的文本?

HTML不是我写的,所以这就是我必须要处理的.我知道在编写html时将文本包装在标签中会很简单,但同样,html是预编写的.

tags jquery text

363
推荐指数
9
解决办法
16万
查看次数

将HTML放在Html.ActionLink()中,加上没有链接文本?

我有两个问题:

  1. 我想知道Html.ActionLink()在MVC视图中使用时我怎么能显示没有链接文本(实际上,这是Site.Master).

没有一个不允许链接文本的重载版本,当我尝试只传入一个空白时string,编译器告诉我它需要一个非空字符串.

我怎样才能解决这个问题?

  1. 我需要<span>在锚标记中放置标记,但它不能使用Html.ActionLink();.我想看看以下输出:

    跨文本

如何在ASP.NET MVC中将标记放在锚标记内?

.net c# asp.net-mvc actionlink

162
推荐指数
5
解决办法
16万
查看次数

使用jQuery比较两个Javascript对象数组

我有两个JavaScript对象数组,我想比较它们是否相同.对象可能不会(并且很可能不会)在每个数组中具有相同的顺序.每个数组不应超过10个对象.我认为jQuery可能有一个优雅的解决方案来解决这个问题,但我无法在网上找到太多.

我知道一个粗暴的嵌套$.each(array, function(){})解决方案可以工作,但是有没有我不知道的内置函数?

谢谢.

javascript arrays jquery compare object

91
推荐指数
4
解决办法
12万
查看次数

将CSS应用于jQuery对话框按钮

所以我目前有一个带有两个按钮的jQuery对话框:Save and Close.我使用下面的代码创建对话框:

$dialogDiv.dialog({
    autoOpen: false,
    modal: true,
    width: 600,
    resizable: false,
    buttons: {
        Cancel: function() {
                        // Cancel code here
        },
        'Save': function() {
                        // Save code here
        }
    },
    close: function() {
        // Close code here (incidentally, same as Cancel code)
    }
});
Run Code Online (Sandbox Code Playgroud)

但是,使用此代码时,两个按钮的颜色相同.我希望我的取消按钮与我的保存颜色不同.有没有办法使用一些内置的jQuery选项来做到这一点?我没有从文档中获得太多帮助.

请注意,我正在创建的"取消"按钮是预定义类型,但"保存"我自己定义.不确定这是否会对问题产生任何影响.

任何帮助,将不胜感激.谢谢.

更新:共识是这里有两条道路:

  1. 使用像firebug这样的Firefox插件检查HTML ,并记下jQuery应用于按钮的CSS类,并尝试覆盖它们.注意:在我的HTML中,两个按钮都使用了完全相同的CSS类,没有唯一的ID,因此该选项已经用完了.
  2. 在打开的对话框上使用jQuery选择器来捕获我想要的按钮,然后添加一个CSS类.

我使用了第二个选项,并使用了jQuery find()方法,因为我认为这比使用更合适:first或:first-child b/c我想要更改的按钮不一定是列出的第一个按钮标记.使用find,我只需指定按钮的名称,并以这种方式添加CSS.我最终得到的代码如下:

$dialogDiv.dialog({
    autoOpen: false,
    modal: true,
    width: 600,
    resizable: false,
    buttons: {
        Cancel: function() {
                        // Cancel code here
        },
        'Save': function() …
Run Code Online (Sandbox Code Playgroud)

css jquery dialog jquery-ui button

77
推荐指数
3
解决办法
11万
查看次数

如何指定(覆盖)JQuery图标颜色

我已经在我的网络应用程序中充分利用了jQuery图标,但是我想要使用我默认无法实现的颜色.我目前正在使用"State Street"主题,主要使用绿色.但我有一个带有白色文字的红色框,并且想要使用白色的图标.主题提供了白色图标,但只有当图标位于具有"ui-state-focus"类的div(或其他容器)内时才会应用它们.这会使图标变白,但会将背景颜色更改为绿色,我想将其保留为红色.

是否有任何方式(最有可能通过CSS)覆盖jQuery用于图标的背景图像,以便我可以使用不同的颜色?

谢谢.

澄清:我想这对我发布我目前正在使用的HTML有帮助:

<!-- currently produces a default 'grey' icon color -->
<!-- this b/c no jquery ui class (like ui-state-focus) given for errorMessage div -->
<div id="errorMessage">
    <span class="ui-icon ui-icon-alert" style="float: left"></span>
    Only 1 Activity can be added at a time 
</div>
Run Code Online (Sandbox Code Playgroud)

我也有CSS:

.dialog #errorMessage
{
    /*display: none;*/
    background-color: #CC3300;
    color: #FFFFFF;
    font-weight: bold;
    padding-top: 3px;
    padding-bottom: 3px;
    vertical-align: bottom;
    bottom: auto;
    font-size: .80em;
    width: 100%
}
Run Code Online (Sandbox Code Playgroud)

"display:none"目前已被注释掉,所以我可以看到它.我确实将它设置为fadeIn上的错误捕获.再次感谢您的帮助.

css jquery icons jquery-ui

61
推荐指数
3
解决办法
7万
查看次数

C#和ASP.NET MVC:在视图中使用#if指令

我有一个名为"RELEASE"的条件编译符号,我在Visual Studio的项目属性中指出了这个符号.我想在定义RELEASE符号时将一些特定的CSS应用于元素,并且我试图从视图中执行此操作,但它似乎不起作用.

我的视图代码看起来像这样(为了演示目的缩短了一点):

<% #if (RELEASE) %>
    <div class="releaseBanner">Banner text here</div>
<% #else %>
    <div class="debugBanner">Banner text here</div>
<% #endif %>
Run Code Online (Sandbox Code Playgroud)

使用此代码,并使用RELEASE符号集,'else'代码正在运行,我正在使用debugBanner类获取div.所以似乎并不认为RELEASE是定义的.值得注意的是,我在.cs文件中的实际C#代码正在识别RELEASE并运行正确的代码.这只是给我这个问题的观点.

有没有人对此有任何见解?任何帮助,将不胜感激.谢谢.

澄清:我应该已经提到过这个视图已经是局部视图了,我只是在需要它的页面中进行渲染.那是因为这些横幅将出现在某些页面而不是其他页面上.因此,即使通过以下方式将其渲染为局部视图:

Html.RenderPartial("BannerView");

它不起作用.

c# asp.net-mvc conditional debug-symbols

46
推荐指数
4
解决办法
3万
查看次数

在$ .getJSON函数期间设置的变量只能在函数内访问

这可能更像是一个范围问题.我正在尝试在$ .getJSON函数中设置JSON对象,但我需要能够在回调之外使用该对象.

var jsonIssues = {};  // declare json variable

$.getJSON("url", function(data) {
    jsonIssues = data.Issues;
});

// jsonIssues not accessible here
Run Code Online (Sandbox Code Playgroud)

在另一篇文章中提到了类似这样的问题,并且一致认为我需要在JSON对象中做的任何事情都需要在回调函数中完成,并且不能在其他任何地方访问.我真的没办法在$ .getJSON回调之外继续访问/操作那个JSON对象吗?如何返回变量或设置全局?

我很感激任何帮助.这似乎不对......

更新:

尝试将$ .ajax()异步设置设置为false,并运行相同的代码,没有运气.我试过的代码如下:

var jsonIssues = {};  // declare json variable

$.ajax({ async: false });

$.getJSON("url", function(data) {
    jsonIssues = data.Issues;
});

// jsonIssues still not accessible here
Run Code Online (Sandbox Code Playgroud)

另外,我有几个响应,全局变量应该可以正常工作.我应该澄清所有这些代码都在其中$(document).ready(function() {.要设置全局变量,我应该在document.ready之前声明它吗?因此:

var jsonIssues = {};

$(document).ready(function() {

  var jsonIssues = {};  // declare json variable

  $.getJSON("url", function(data) {
      jsonIssues = data.Issues;
  });

  // now …
Run Code Online (Sandbox Code Playgroud)

javascript variables jquery scope callback

45
推荐指数
3
解决办法
6万
查看次数

将JavaScript对象添加到JavaScript对象

我想在另一个JavaScript对象中使用JavaScript对象:

Issues:

  - {"ID" : "1", "Name" : "Missing Documentation", "Notes" : "Issue1 Notes"}
  - {"ID" : "2", "Name" : "Software Bug", "Notes" : "Issue2 Notes, blah, blah"}
  - {"ID" : "2", "Name" : "System Not Ready", "Notes" : "Issue3 Notes, etc"}
  // etc...
Run Code Online (Sandbox Code Playgroud)

所以,我想要"问题"来保存这些JavaScript对象,这样我就可以说问题[0] .Name,或者问题[2] .ID等.

我创建了外部问题JavaScript对象:

var jsonIssues = {};
Run Code Online (Sandbox Code Playgroud)

我需要向它添加JavaScript对象,但不知道如何.我想能够说:

Issues<code here>.Name = "Missing Documentation";
Issues<code here>.ID = "1";
Issues<code here>.Notes = "Notes, notes notes";
Run Code Online (Sandbox Code Playgroud)

有没有办法做到这一点?谢谢.

更新:给出答案,声明一个数组,并根据需要推送JavaScript对象:

var jsonArray_Issues = new Array();

jsonArray_Issues.push( { "ID" : …
Run Code Online (Sandbox Code Playgroud)

javascript add object

38
推荐指数
4
解决办法
12万
查看次数

jQuery选择器:选择具有特定类和"标题"属性的元素

这应该是一个简单的,但我无法在任何地方找到一个好的例子.我正在尝试在我的页面上选择一个具有"statuslight"类和三个选项之一的title属性的特定元素.选项(它将取决于)存储在名为"currentStatus"的变量中.我已经看过一些例子,我猜这是正确的轨道,但我需要确定:

$(".statuslight[title]='" + currentStatus + "'");
Run Code Online (Sandbox Code Playgroud)

jquery attributes class title jquery-selectors

33
推荐指数
1
解决办法
5万
查看次数