三种方案避免CSS语法与Smarty冲突

开发 前端
熟悉CSS的人很快就会发现Smarty和CSS的语法存在冲突,因为二者都需要使用大括号{},这里向大家简单介绍一下避免避免Smarty与CSS语法冲突的三种方法,相信你一定会感兴趣。

本文向大家描述一下避免Smarty与CSS语法冲突的三种方法,Smarty和CSS的语法存在冲突,因为二者都需要使用大括号{}。如果简单地将CSS标记嵌入到HTML文档首部,将导致"不可识别标记"错误。

避免Smarty与CSS语法冲突

熟悉CSS的人很快就会发现Smarty和CSS的语法存在冲突,因为二者都需要使用大括号{}。如果简单地将CSS标记嵌入到HTML文档首部,将导致"不可识别标记"错误:

  1. <html> 
  2. <head> 
  3. <title>{$title}</title> 
  4. <styletypestyletype="text/css"> 
  5. p{  
  6. margin::2px  
  7. }  
  8. </style> 
  9. </head> 
  10. ...  

不要担心,因为我们有3种解决方案。

一、使用link标记从另一个文件中提取样式信息:

  1. <html> 
  2. <head> 
  3. <title>{$title}</title> 
  4. <linkrellinkrel="stylesheet"type="text/css"href="default.css"/> 
  5. </head> 
  6. ...  
  7.  

二、使用Smarty的literal标记将样式表信息包围起来

这些标记告诉Smarty不要解析该标记内的任何内容:
 

  1. <html> 
  2. <head> 
  3. <title>{$title}</title> 
  4. {literal}  
  5. <styletypestyletype="text/css"> 
  6. p{  
  7. margin::2px  
  8. }  
  9. </style> 
  10. {/literal}  
  11. </head> 
  12. ...  

 三、修改Smarty的默认定界符

可以通过设置center_delimiter和center_delimiter属性来做到这一点:
 

  1. <?php 
  2. require("Smarty.class.php");  
  3. $smarty=newSmarty;  
  4. $smarty->left_delimiter='';  
  5. $smarty->right_delimiter='';  
  6. ...  
  7. ?> 
  8.  

  虽然3种解决方案都能解决问题,但其中第一种可能是最方便的,因为将CSS放在单独的文件中是一种常见的实践做法。此外,这种解决方案不需要修改Smarty的重要默认配置(定界符)。
 

【编辑推荐】

  1. CSS中margin属性及其使用探究
  2. CSS样式实现快速定位bug的六大技巧
  3. CSS中link和@import的区别
  4. CSS2.0中page-break-after属性用法
  5. 技术分享 使用不同CSS样式兼容多种浏览器

 

 

责任编辑:佚名 来源: css3-html5.com
相关推荐

2015-03-10 13:50:42

smartycss语法

2010-09-02 16:26:59

CSS命名

2022-06-20 08:50:16

TypeScript类型语法

2013-04-09 09:55:59

云计算SaaS

2010-09-07 16:31:27

CSS

2023-12-04 09:31:13

CSS卡片

2021-12-23 06:57:32

企业策略数据

2010-09-01 12:50:04

CSS清除浮动

2010-09-14 15:10:49

CSS注释

2017-07-03 18:24:39

MySQL数据冗余

2010-09-08 13:29:48

CSS

2010-08-24 14:47:48

CSS居中

2022-07-22 20:00:01

高可用路由

2022-03-22 10:24:48

Linux开源Elasticsea

2010-09-06 10:04:31

CSS样式表

2010-09-30 14:40:45

2010-09-25 17:17:19

2010-05-25 18:50:22

MySQL安装

2011-09-05 12:43:23

Sencha Touc事件

2022-08-19 14:24:30

forPythonpythonic
点赞
收藏

51CTO技术栈公众号