Css Combres不修复相对URL(尽管有筛选器)?
更新:下面是一个我认为存在问题的CSS示例:Css Combres不修复相对URL(尽管有筛选器)?,css,filter,relative-path,combres,Css,Filter,Relative Path,Combres,更新:下面是一个我认为存在问题的CSS示例: .ui-widget-content { border: 1px solid #aaaaaa/*{borderColorContent}*/; background: #ffffff/*{bgColorContent}*/ url(images/ui-bg_flat_75_ffffff_40x100.png)/*{bgImgUrlContent}*/ 50%/*{bgContentXPos}*/ 50%/*{bgContentYPos}*/ repe
.ui-widget-content { border: 1px solid #aaaaaa/*{borderColorContent}*/; background: #ffffff/*{bgColorContent}*/ url(images/ui-bg_flat_75_ffffff_40x100.png)/*{bgImgUrlContent}*/ 50%/*{bgContentXPos}*/ 50%/*{bgContentYPos}*/ repeat-x/*{bgContentRepeat}*/; color: #222222/*{fcContent}*/; }
更新-在codeplex上为combres创建了问题内跟踪程序
更新:我查看了日志,发现发生了什么-
2011-10-24 16:32:20,490 [15] WARN Combres.Filters.FixUrlsInCssFilter - Cannot fix url url(images/ui-icons_454545_256x240.png)
System.ArgumentOutOfRangeException: Length cannot be less than zero.
Parameter name: length
at System.String.InternalSubStringWithChecks(Int32 startIndex, Int32 length, Boolean fAlwaysCopy)
at System.String.Substring(Int32 startIndex, Int32 length)
at Combres.Filters.FixUrlsInCssFilter.FixUrl(Resource resource, Match match)
那么,我可以得到源代码并查看它吗?或者我需要把它放在combres问题跟踪程序上吗
我正在使用过滤器-
<filter type="Combres.Filters.FixUrlsInCssFilter, Combres" />
有人能给我一些建议吗?我发现了一些东西,但它的解决方案对我不起作用
更新:这是我的combres.xml,以防万一-
<?xml version="1.0" encoding="utf-8" ?>
<!--
This file contains basic settings needed for most web apps.
For full Combres settings (with explanation), refer to the sample definition file: combres_full_with_annotation.xml
Also, refer to Combres' documentation: http://combres.codeplex.com/documentation
-->
<combres xmlns='urn:combres'>
<filters>
<filter type="Combres.Filters.FixUrlsInCssFilter, Combres" acceptedResourceSets="LogCreateCss" />
<filter type="Combres.Filters.DotLessCssFilter, Combres" acceptedResourceSets="LogCreateCss" />
</filters>
<cssMinifiers>
<minifier name="yui" type="Combres.Minifiers.YuiCssMinifier, Combres">
<param name="CssCompressionType" type="string" value="StockYuiCompressor" />
<param name="ColumnWidth" type="int" value="-1" />
</minifier>
</cssMinifiers>
<jsMinifiers>
<minifier name="msajax" type="Combres.Minifiers.MSAjaxJSMinifier, Combres" binderType="Combres.Binders.SimpleObjectBinder, Combres">
<param name="CollapseToLiteral" type="bool" value="true" />
<param name="EvalsAreSafe" type="bool" value="true" />
<param name="MacSafariQuirks" type="bool" value="true" />
<param name="CatchAsLocal" type="bool" value="true" />
<param name="LocalRenaming" type="string" value="CrunchAll" />
<param name="OutputMode" type="string" value="SingleLine" />
<param name="RemoveUnneededCode" type="bool" value="true" />
<param name="StripDebugStatements" type="bool" value="true" />
</minifier>
<minifier name="yui" type="Combres.Minifiers.YuiJSMinifier, Combres">
<param name="IsVerboseLogging" type="bool" value="false" />
<param name="IsObfuscateJavascript" type="bool" value="true" />
<param name="PreserveAllSemicolons" type="bool" value="false" />
<param name="DisableOptimizations" type="bool" value="true" />
<param name="LineBreakPosition" type="int" value="-1" />
</minifier>
</jsMinifiers>
<resourceSets url="~/combres.axd" defaultDuration="30"
defaultVersion="auto"
defaultDebugEnabled="false"
defaultJSMinifierRef="msajax"
defaultCssMinifierRef="yui">
<resourceSet name="siteCss" type="css" minifierRef="yui">
<resource path="\Content\StyleSheets\reset.css" />
<resource path="\Content\StyleSheets\960.css" />
<resource path="\Content\StyleSheets\Site960.css" />
<resource path="\Content\StyleSheets\Site.css" />
</resourceSet>
<resourceSet name="siteJs" type="js" minifierRef="msajax">
<resource path="\Scripts\jquery-1.5.1.min.js" />
<resource path="\Content\Scripts\blockUI.js" />
</resourceSet>
<resourceSet name="overviewCss" type="css" minifierRef="yui">
<resource path="\Content\Plugins\fancybox\css\jquery.fancybox-1.3.4.css" />
<resource path="\Content\StyleSheets\overview_kam.css" />
</resourceSet>
<resourceSet name="overviewJs" type="js" minifierRef="msajax">
<resource path="\Content\Plugins\fancybox\scripts\jquery.fancybox-1.3.4.pack.js" />
</resourceSet>
<resourceSet name="LogCreateCss" type="css" minifierRef="yui">
<resource path="\Content\Plugins\fancybox\css\jquery.fancybox-1.3.4.css" />
</resourceSet>
<resourceSet name="activityLogCloseCreateJs" type="js" minifierRef="msajax">
<resource path="\Content\Plugins\fancybox\scripts\jquery.fancybox-1.3.4.pack.js" />
<resource path="\Content\Plugins\fancybox\scripts\jquery.fancybox-1.3.4.js" />
</resourceSet>
<resourceSet name="LogCreateCss" type="css" minifierRef="yui">
<resource path="\Content\StyleSheets\Site.css" />
<resource path="\Content\Plugins\jquerySpinner\themes\base\jquery.ui.all.css" />
<resource path="\Content\Plugins\jquerySpinner\themes\base\jquery-ui.css" />
<resource path="\Content\Plugins\jquerySpinner\themes\base\jquery.ui.accordion.css" />
<resource path="\Content\Plugins\jquerySpinner\themes\base\jquery.ui.autocomplete.css" />
<resource path="\Content\Plugins\jquerySpinner\themes\base\jquery.ui.button.css" />
<resource path="\Content\Plugins\jquerySpinner\themes\base\jquery.ui.core.css" />
<resource path="\Content\Plugins\jquerySpinner\themes\base\jquery.ui.datepicker.css" />
<resource path="\Content\Plugins\jquerySpinner\themes\base\jquery.ui.dialog.css" />
<resource path="\Content\Plugins\jquerySpinner\themes\base\jquery.ui.menu.css" />
<resource path="\Content\Plugins\jquerySpinner\themes\base\jquery.ui.progressbar.css" />
<resource path="\Content\Plugins\jquerySpinner\themes\base\jquery.ui.resizable.css" />
<resource path="\Content\Plugins\jquerySpinner\themes\base\jquery.ui.selectable.css" />
<resource path="\Content\Plugins\jquerySpinner\themes\base\jquery.ui.slider.css" />
<resource path="\Content\Plugins\jquerySpinner\themes\base\jquery.ui.spinner.css" />
<resource path="\Content\Plugins\jquerySpinner\themes\base\jquery.ui.tabs.css" />
<resource path="\Content\Plugins\jquerySpinner\themes\base\jquery.ui.theme.css" />
<resource path="\Content\Plugins\jquerySpinner\themes\base\jquery.ui.tooltip.css" />
<resource path="\Content\Plugins\jquerySpinner\demos\demos.css" />
</resourceSet>
<resourceSet name="LogCreateJs" type="js" minifierRef="msajax" >
<resource path="\Content\Plugins\jquerySpinner\jquery-1.4.3.js" />
<resource path="\Content\Scripts\ActivityLog\Create.js" />
<resource path="\Content\Plugins\fancybox\scripts\jquery.fancybox-1.3.4.pack.js" />
<resource path="\Content\Plugins\jquerySpinner\external\jquery.mousewheel-3.0.4.js" />
<resource path="\Content\Plugins\jquerySpinner\external\glob.js" />
<resource path="\Content\Plugins\jquerySpinner\external\glob.de-DE.js" />
<resource path="\Content\Plugins\jquerySpinner\external\glob.ja-JP.js" />
<resource path="\Content\Plugins\jquerySpinner\ui\jquery.ui.core.js" />
<resource path="\Content\Plugins\jquerySpinner\ui\jquery.ui.widget.js" />
<resource path="\Content\Plugins\jquerySpinner\ui\jquery.ui.button.js" />
<resource path="\Content\Plugins\jquerySpinner\ui\jquery.ui.spinner.js" />
</resourceSet>
</resourceSets>
</combres>
我认为css的图像部分格式不正确;请尝试以下方法:
url('images/ui-bg_flat_75_ffffff_40x100.png') /*{bgImgUrlContent}*/
请注意,添加了单引号以及结尾“)”和注释块之间的空格
根据经验,我可以建议使用应用程序根相对语法来保持更干净,例如,我将更改您必须执行的操作:
url('~/images/ui-bg_flat_75_ffffff_40x100.png') /*{bgImgUrlContent}*/
更新:
另一种选择是编写自己的ISingleContentFilter
实现,该实现更能容忍css文件中出现的语法类型。你可以看一下combres one,这是一个很好的起点
更新:
如果您已经创建了自己的过滤器改进版本,只需将其作为web项目的一部分编译并在combres.xml中引用即可:
<filters>
<filter type="YourProject.MyBetterFilter, YourProject" />
</filters>
无需完全重新编译(和mantain)一个自定义版本的Combres以这种方式扩展它。你能发布css文件中显示应该修复的url的部分吗?@DanP我已经用css的摘录更新了这个问题。是的。我们正在使用插件和其他附加组件,所以如果这是解决方案,这意味着我需要到处更改url。另外,
~
是asp.net特有的东西,因此我不确定将来是否会因为某种原因不使用combres,我不确定它是否会起作用。我非常感谢您的帮助,让我们看看是否还有其他方法可以做到这一点。您可以随时编写自己的ISingleContentFilter实现,该实现对此类语法更宽容,我以前也这样做过,以处理一些特殊情况。嗯……有没有一个示例……或者您可以告诉我执行该操作的步骤吗?谢谢因此,我下载了源代码并对其进行了修改,但我想我不能在我的项目中直接使用合并的combres.dll,因为我已经使用NuGet安装了combres,并且它当前使用不同的dll,而不是一个。是否有任何方法可以让combres.dll替换为新更改的源代码dll。如果不是,我只是删除所有以前的引用,然后需要引用合并的combres.dll以使一切正常工作?只需在web项目中编译新的筛选器,并在combres.xml文件中相应地引用它,就没有理由仅为此使用自定义版本的combres本身。
<filters>
<filter type="YourProject.MyBetterFilter, YourProject" />
</filters>