我需要一些帮助,应该分裂CSSText中的某个正则表达式(未选择器,但是内{}的部分)成ASSOC在PHP键 - >值对阵列
假设选择器部分被去除并且有例如这样的:
color: black;
font-family: \"Courier New\";
background: url(\"test.png\");
color: red;
是该字符串逃过我没有能够做到这提取{}部分时。
但:
如果背景是dataURI还是有内容的道具组如:
content:'1.test;2.blabla;';
background: white url('
AANSUhEUgAAABAAAAAQAQMAAAAlPW0iAAAABl...') no-repeat scroll left top;
拆分正则表达式使用:
preg_match_all('/([\w-]+)\s*:\s*([^;]*)\s*;?/i', $css, $matches, PREG_SET_ORDER);
失败:(
我不是在正则表达式亲和需要你的意见如何在不刹车“;” 外观里面\“... \”里面的字符串。
它应该是捕获组中([^] *),其作为我发现手段:匹配任何单个字符并不; 并重复0次或更多次。
提前致谢!
如果这不是学习的目的,我真的会建议使用一个库,而不是重新发明轮子:)喜欢的东西的https://github.com/sabberworm/PHP-CSS-Parser 。
如果你不关心你的意见可以使用这样的事情来处理引用内容与转义:
/([\w-]++) \s*+ : \s*+ ( (?: [^;'"]++ | "(?:[^"\\]|\\.)*+" | '(?:[^'\\]|\\.)*+' )*+ ) \s* ;?/x
(不要忘了一倍+逃脱\\
在PHP中引用的时候。)
我制作一个简单的parseCSS
使用一个简单的状态机的功能。 你可以阅读代码,您可以进一步扩展到你所需要的。 所述的algorihm的复杂度为O(N),其中N是CSS的长度。
function parseCSS($css)
{
// State variable
$isOption = true; $isValue = false; $isQuote = ''; $arr=array();
// Buffer variable
$option = ''; $value = '';
for($i = 0; $i < strlen($css); $i++) {
if ($isOption) {
if ($css[$i] == ':') {
$isValue = true; $isOption = false;
} else {
$option .= $css[$i];
}
} elseif ($isValue) {
if ($isQuote == $css[$i]) {
$isQuote = ''; $value .= $css[$i];
} elseif ($isQuote != '') {
$value .= $css[$i];
} else {
if (($css[$i] == "'") || ($css[$i] == '"')) {
$isQuote = $css[$i]; $value .= $css[$i];
} elseif ($css[$i] == ';') {
$arr[trim($option)] = trim($value);
$option = ''; $value = '';
$isOption = true; $isValue = false;
} else {
$value .= $css[$i];
}
}
}
}
return $arr;
}
$css = parseCSS
(
"content:'1.test;2.blabla;';
background: white url('
AANSUhEUgAAABAAAAAQAQMAAAAlPW0iAAAABl...') no-repeat scroll left top;"
);
var_dump($css);
使用此功能
function BreakCSS($CSS) {
$results = array();
foreach(explode(';', $CSS) AS $attr)
if (strlen(trim($attr)) > 0) // for missing semicolon on last element, which is legal
{
list($name, $value) = explode(':', $attr);
$results[trim($name)] = trim($value);
}
return $results;
}