使用 php 在 css 中搜索特定的 class
Search a particular class in css with php
我正在为 Web 项目使用 flaticon。我必须在 div 中显示文件 flaticonicon.css.
中存在的所有图标
所以我必须推断 flaticonicon-add121 , flaticonicon-alarm57 , flaticonicon-appointment等
为此我编写了以下代码
$handle = @fopen("flaticonicon.css", "r");
$a = 0;
if ($handle) {
while (($buffer = fgets($handle, 4096)) !== false) {
if (strpos($buffer,':before') !== false) {
$a++;
if($a > 1 && $buffer[0] != "}"){
$c = preg_split("/:/", $buffer , NULL);
$c = $c[0];
$c = substr($c, 1 , strlen($c));
echo "<span class='".$c."'></span>";
echo "\r\n";
}
}
}
fclose($handle);
}
在这种 css
上效果很好
@font-face {
font-family: "FlaticonIcon";
src: url("flaticonicon.eot");
src: url("flaticonicon.eot#iefix") format("embedded-opentype"),
url("flaticonicon.woff") format("woff"),
url("flaticonicon.ttf") format("truetype"),
url("flaticonicon.svg") format("svg");
font-weight: normal;
font-style: normal;
}
[class^="flaticonicon-"]:before, [class*=" flaticonicon-"]:before,
[class^="flaticonicon-"]:after, [class*=" flaticonicon-"]:after {
font-family: FlaticonIcon;
font-size: 20px;
font-style: normal;
margin-left: 20px;
}
.flaticonicon-add121:before {
content: "\e000";
}
.flaticonicon-alarm57:before {
content: "\e001";
}
.flaticonicon-appointment:before {
content: "\e002";
}
.flaticonicon-armchair1:before {
content: "\e003";
}
.flaticonicon-audio49:before {
content: "\e004";
}
.flaticonicon-baseball24:before {
content: "\e005";
}
.flaticon-etc etc
问题是 css 文件不会保持原样,在项目结束时会缩小成这样,这样我的代码就无法正确读取所有 类 的图标。
@font-face{font-family:"FlaticonIcon";src:url("flaticonicon.eot");src:url("flaticonicon.eot#iefix") format("embedded-opentype"),url("flaticonicon.woff") format("woff"),url("flaticonicon.ttf") format("truetype"),url("flaticonicon.svg") format("svg");font-weight:normal;font-style:normal}[class^="flaticonicon-"]:before,[class*=" flaticonicon-"]:before,[class^="flaticonicon-"]:after,[class*=" flaticonicon-"]:after{font-family:FlaticonIcon;font-size:20px;font-style:normal;margin-left:20px}.flaticonicon-add121:before{content:"\e000"}.flaticonicon-alarm57:before{content:"\e001"}.flaticonicon-appointment:before{content:"\e002"}.flaticonicon-armchair1:before{content:"\e003"}.flaticonicon-audio49:before{content:"\e004"}.flaticonicon-baseball24:before{content:"\e005"}.flaticonicon-basin:before{content:"\e006"}.flaticonicon-basketball32:before{content:"\e007"}.flaticonicon-bath2:before{content:"\e008"}.flaticonicon-bathroom1:before{content:"\e009"}.flaticonicon- ........ }
我看过类似的问题,我认为正确的解决方案是使用正则表达式
更新..
即使只是能够推断 {....} 之间的文本,这也会非常有用,到那时它会很简单
更新..
这可以帮助
$c = file_get_contents('flaticonicon.css');
$cc = split('[{}]', $c);
更新..
这是我的解决方案
$c = file_get_contents('flaticonicon.css');
$cc = split('[{}]', $c);
for($i = 0 ; $i < count($cc) ; $i++){
if(substr($cc[$i], 0 , 14) == ".flaticonicon-"){
$app = preg_split("/:/", $cc[$i] , null);
$app = substr($app[0], 1,strlen($app[0]));
echo $app."<br>";
}
}
我不是正则表达式的明星,但它似乎可以解决问题:
$matches = array();
$t = preg_match_all('/\.flaticon[^:]*/', $string, $matches);
echo '<pre>'.print_r($matches[0],true).'</pre>';
您只需删除前导点即可获取名称。压缩后的结果 css:
[0] => .flaticonicon-add121
[1] => .flaticonicon-alarm57
[2] => .flaticonicon-appointment
[3] => .flaticonicon-armchair1
[4] => .flaticonicon-audio49
[5] => .flaticonicon-baseball24
[6] => .flaticonicon-basin
[7] => .flaticonicon-basketball32
[8] => .flaticonicon-bath2
[9] => .flaticonicon-bathroom1
我正在为 Web 项目使用 flaticon。我必须在 div 中显示文件 flaticonicon.css.
中存在的所有图标所以我必须推断 flaticonicon-add121 , flaticonicon-alarm57 , flaticonicon-appointment等
为此我编写了以下代码
$handle = @fopen("flaticonicon.css", "r");
$a = 0;
if ($handle) {
while (($buffer = fgets($handle, 4096)) !== false) {
if (strpos($buffer,':before') !== false) {
$a++;
if($a > 1 && $buffer[0] != "}"){
$c = preg_split("/:/", $buffer , NULL);
$c = $c[0];
$c = substr($c, 1 , strlen($c));
echo "<span class='".$c."'></span>";
echo "\r\n";
}
}
}
fclose($handle);
}
在这种 css
上效果很好@font-face {
font-family: "FlaticonIcon";
src: url("flaticonicon.eot");
src: url("flaticonicon.eot#iefix") format("embedded-opentype"),
url("flaticonicon.woff") format("woff"),
url("flaticonicon.ttf") format("truetype"),
url("flaticonicon.svg") format("svg");
font-weight: normal;
font-style: normal;
}
[class^="flaticonicon-"]:before, [class*=" flaticonicon-"]:before,
[class^="flaticonicon-"]:after, [class*=" flaticonicon-"]:after {
font-family: FlaticonIcon;
font-size: 20px;
font-style: normal;
margin-left: 20px;
}
.flaticonicon-add121:before {
content: "\e000";
}
.flaticonicon-alarm57:before {
content: "\e001";
}
.flaticonicon-appointment:before {
content: "\e002";
}
.flaticonicon-armchair1:before {
content: "\e003";
}
.flaticonicon-audio49:before {
content: "\e004";
}
.flaticonicon-baseball24:before {
content: "\e005";
}
.flaticon-etc etc
问题是 css 文件不会保持原样,在项目结束时会缩小成这样,这样我的代码就无法正确读取所有 类 的图标。
@font-face{font-family:"FlaticonIcon";src:url("flaticonicon.eot");src:url("flaticonicon.eot#iefix") format("embedded-opentype"),url("flaticonicon.woff") format("woff"),url("flaticonicon.ttf") format("truetype"),url("flaticonicon.svg") format("svg");font-weight:normal;font-style:normal}[class^="flaticonicon-"]:before,[class*=" flaticonicon-"]:before,[class^="flaticonicon-"]:after,[class*=" flaticonicon-"]:after{font-family:FlaticonIcon;font-size:20px;font-style:normal;margin-left:20px}.flaticonicon-add121:before{content:"\e000"}.flaticonicon-alarm57:before{content:"\e001"}.flaticonicon-appointment:before{content:"\e002"}.flaticonicon-armchair1:before{content:"\e003"}.flaticonicon-audio49:before{content:"\e004"}.flaticonicon-baseball24:before{content:"\e005"}.flaticonicon-basin:before{content:"\e006"}.flaticonicon-basketball32:before{content:"\e007"}.flaticonicon-bath2:before{content:"\e008"}.flaticonicon-bathroom1:before{content:"\e009"}.flaticonicon- ........ }
我看过类似的问题,我认为正确的解决方案是使用正则表达式
更新..
即使只是能够推断 {....} 之间的文本,这也会非常有用,到那时它会很简单
更新..
这可以帮助
$c = file_get_contents('flaticonicon.css');
$cc = split('[{}]', $c);
更新..
这是我的解决方案
$c = file_get_contents('flaticonicon.css');
$cc = split('[{}]', $c);
for($i = 0 ; $i < count($cc) ; $i++){
if(substr($cc[$i], 0 , 14) == ".flaticonicon-"){
$app = preg_split("/:/", $cc[$i] , null);
$app = substr($app[0], 1,strlen($app[0]));
echo $app."<br>";
}
}
我不是正则表达式的明星,但它似乎可以解决问题:
$matches = array();
$t = preg_match_all('/\.flaticon[^:]*/', $string, $matches);
echo '<pre>'.print_r($matches[0],true).'</pre>';
您只需删除前导点即可获取名称。压缩后的结果 css:
[0] => .flaticonicon-add121 [1] => .flaticonicon-alarm57 [2] => .flaticonicon-appointment [3] => .flaticonicon-armchair1 [4] => .flaticonicon-audio49 [5] => .flaticonicon-baseball24 [6] => .flaticonicon-basin [7] => .flaticonicon-basketball32 [8] => .flaticonicon-bath2 [9] => .flaticonicon-bathroom1