随笔 - 2146  文章 - 19 评论 - 11846 阅读 - 1267万


IW 会把大多数的视觉属性转换为 CSS; 我们主动使用 CSS 要分两步:

第一步:
{通过窗体的 StyleSheet 属性指定要链接的 CSS 文件}
procedure TIWForm1.IWAppFormCreate(Sender: TObject);
begin
  StyleSheet.Filename := 'MyCss1.css'; //CSS 文件须放在 wwwroot 下
//  StyleSheet.URL := 'http://...';    //外链
end;

{假如站点级的 CSS ... TIWServerController.OnCreate}
procedure TIWServerController.IWServerControllerBaseCreate(Sender: TObject);
begin
  StyleSheet.Filename := 'MyCss1.css'; //CSS 文件须放在 wwwroot 下
//  StyleSheet.URL := 'http://...';    //外链
end;


第二步:
{为要使用样式的控件指定 Css 属性}
procedure TIWForm1.IWAppFormCreate(Sender: TObject);
begin
  StyleSheet.Filename := 'MyCss1.css';
  IWMemo1.Css := 'Class1'; //假如 MyCss1.css 中有个 Class1 的类, 如: .Class {font-size: 32px; }

  IWMemo1.StyleRenderOptions.RenderFont := False; //一般情况下, 还需要同时调整下 StyleRenderOptions 属性
end;

{------------------------------------------------------------------
关于 StyleRenderOptions 属性: 

如果我们给控件使用了 CSS, 就有可能和控件本身的属性发生冲突, 用哪一个呢? 这需要控件的 StyleRenderOptions 属性来决定!

它也是个类(IWTypes.TIWStyleRenderOptions < TPersistent < TObject), 该类只有几个布尔属性:
property RenderSize: Boolean       //
property RenderPosition: Boolean   //
property RenderFont: Boolean       //
property RenderZIndex: Boolean     //
property RenderVisibility: Boolean //
property RenderStatus: Boolean     //Enabled
property RenderPadding: Boolean    //
property RenderBorder: Boolean     //
property RenderAbsolute: Boolean   //
property UseDisplay: Boolean       //

当对应值为 False 时才可以使用相应的 CSS.
-------------------------------------------------------------------}


CSS 的诸多操作类似与 JavaScript, 譬如:
procedure TIWForm1.IWAppFormCreate(Sender: TObject);
begin
  IWServerController.HTMLHeaders('<link type="text/css" rel="stylesheet" href="MyCss1.css"/>');
  Self.PreHeader.Add('<link type="text/css" rel="stylesheet" href="MyCss2.css"/>');
  Self.ExtraHeader.Add('<link type="text/css" rel="stylesheet" href="MyCss3.css"/>');

  IWServerController.ContentFiles.Add('MyCss4.css');
  Self.ContentFiles.Add('MyCss5.css');
end;


有没有可能直接在代码中写入 CSS 呢?
{使用 ExtraTagParams 属性}
IWLabel1.ExtraTagParams.Add('style = color: #f00; font-size:22px;');

{使用 OnHTMLTag 事件, 需要 uses IWHTMLTag}
procedure TIWForm1.IWLabel1HTMLTag(ASender: TObject; ATag: TIWHTMLTag);
begin
  ATag.AddStringParam('style', 'color: #f00; font-size:22px;');
end;

posted on   万一  阅读(5442)  评论(1编辑  收藏  举报
编辑推荐:
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
历史上的今天:
2008-06-09 再学 GDI+[11]: DrawCurve - 绘制曲线
2008-06-09 判断字符串中子串个数的函数
2008-06-09 再学 GDI+[10]: DrawClosedCurve - 绘制闭合曲线
2008-06-09 再学 GDI+[9]: DrawPolygon - 绘制多边形
2008-06-09 再学 GDI+[8]: DrawRectangles - 绘制一组矩形
2008-06-09 再学 GDI+[7]: DrawLines - 绘制一组直线
2008-06-09 再学 GDI+[6]: DrawPie - 绘制饼形


点击右上角即可分享
微信分享提示