惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

T
The Blog of Author Tim Ferriss
cs.CV updates on arXiv.org
cs.CV updates on arXiv.org
云风的 BLOG
云风的 BLOG
Cyber Security Advisories - MS-ISAC
Cyber Security Advisories - MS-ISAC
P
Palo Alto Networks Blog
D
Docker
H
Hackread – Cybersecurity News, Data Breaches, AI and More
S
Schneier on Security
Engineering at Meta
Engineering at Meta
I
InfoQ
L
LangChain Blog
Cyberwarzone
Cyberwarzone
T
Tenable Blog
WordPress大学
WordPress大学
P
Privacy & Cybersecurity Law Blog
罗磊的独立博客
Apple Machine Learning Research
Apple Machine Learning Research
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
Jina AI
Jina AI
C
CERT Recently Published Vulnerability Notes
Scott Helme
Scott Helme
博客园 - 三生石上(FineUI控件)
酷 壳 – CoolShell
酷 壳 – CoolShell
Know Your Adversary
Know Your Adversary
D
Darknet – Hacking Tools, Hacker News & Cyber Security
The Last Watchdog
The Last Watchdog
Last Week in AI
Last Week in AI
Cloudbric
Cloudbric
S
SegmentFault 最新的问题
爱范儿
爱范儿
Application and Cybersecurity Blog
Application and Cybersecurity Blog
博客园 - 叶小钗
AI
AI
T
Tor Project blog
I
Intezer
T
Threatpost
www.infosecurity-magazine.com
www.infosecurity-magazine.com
V
Visual Studio Blog
N
News and Events Feed by Topic
Latest news
Latest news
S
Security Affairs
博客园 - Franky
Microsoft Security Blog
Microsoft Security Blog
C
Cyber Attacks, Cyber Crime and Cyber Security
K
KPMG report finds enterprise disconnect between AI and its ROI | CIO
B
Blog RSS Feed
C
Cybersecurity and Infrastructure Security Agency CISA
Hugging Face - Blog
Hugging Face - Blog
小众软件
小众软件
S
Securelist

博客园 - 什么都不知道

DataSet的Xml序列化问题 VB.NET的一个小问题 Access is denied的问题 - 什么都不知道 存储过程output参数问题 SQL Server的效率? datagrid刷新问题 使用Visio DrawingControl的应用开发(补) 突起效果的Label WinForm下TextBox的数据绑定和更新 使用Radio按钮选择DataGrid行 如何在运行时加载不处于应用程序目录下的assembly 使用VSA给程序加上脚本支持 删除所有Windows组件 c#中动态装载dll 处理大型xml文件 RedirectToMobilePage的问题 使用Visio 2003 Drawing Control开发应用(3)(4) 使用Visio 2003 Drawing Control开发应用(2) 使用Visio 2003 Drawing Control开发应用(1)
在ASP.NET中嵌入wml标记
什么都不知道 · 2004-09-08 · via 博客园 - 什么都不知道

昨天解决了这么一个问题,是关于Mobile Control的。
用ASP.NET开发WAP程序,使用Mobile Control很方便,也比较容易上手,可是有时候想利用wml的一些元素,有不想很费劲的写adapter。比如:想在页面中添加一个wml的prev元素,如果用wml直接写就可以写成  <anchor title="Back">Back<prev /></anchor>
可是在一个mobile form中如何添加呢?我试了这么几种方法:
1、直接利用Response。就是在该MobileWebForm的Page_Load里面填写
string aa = "<card id=\"card1\" title=\"Title\">";
aa += "<P>";
aa += "<anchor title=\"back\">返回<prev/></anchor>";
aa += "</P>";
Response.Write(aa);
当然应该加一些设备兼容性的工作,这里省略。
这样做的问题是,这样写出来的东西肯定是在页面的最顶端。
2、利用Application_EndRequest
要想将内容放到最后,就要在Response的内容Render完之后再添加,不过直接将上面的代码放到这个事件中,在Openwave中却显示不出来,可能是因为openwave认为这个card已经在结束标志之后了,所以这样做了一下。
在Page_Load中写
string aa = "<card id=\"card1\" title=\"Title\">";
Response.Write(aa);
然后再EndRequest中写
if(this.Request.FilePath.IndexOf("yourmobileform.aspx") != -1)
{
string aa += "<P>";
aa += "<anchor title=\"back\">返回<prev/></anchor>";
aa += "</P>";
Response.Write(aa);
}
就把Openwave骗过去了
3、使用DeviceSpecific控件。
这种方法属于正统解决方法。在Form上拖一个Devicespecific控件,设计为
  <mobile:DeviceSpecific id="DeviceSpecific2" runat="server">
   <Choice Filter="isWML11">
    <FooterTemplate>
     <P>
      <anchor title="back">返回<prev /></anchor>
     </P>
    </FooterTemplate>
   </Choice>
  </mobile:DeviceSpecific>

可能是我不怎么会用Openwave的缘故,openwave不理会我上面的东西。后来就自己加了一个设备筛选器,判断isMobileDevice=true。这样就可以了。
用<FooterTemplate>放在最后,用<HeaderTemplate>和<ScriptTemplate>都放在最上面了。
4、还有就是写自己的Adapter,这个从略,我试过HtmlAdapter,没问题,但是写了一个Wml的Adapter, openwave不理会的,搞不大明白openwave究竟接收什么类型的东西。

做一些补充,前面说的都是放在最前或者最后,要是放在中间怎么办。
可以在Form上放一个Panel,然后将这个DeviceSpecific放在这个panel中,然后在<ContentTemplate>中放wml内容
<P><anchor title="ddd">3eee<prev /></anchor></P>
这后面就可以放你要放的东西了
比如<mobile:Label id="Label1" runat="server">Label</mobile:Label>
可是这个Label不能被代码访问到,所以需要手动添加事件
<mobile:Label id="Label1" runat="server" OnLoad="SetText">Label</mobile:Label>
然后在.cs中加入这个函数实现
public void SetText(object sender,System.EventArgs e)
{
(sender as System.Web.UI.MobileControls.Label).Text = "dkkd";
}
继续更新(2004.9.9)
要放在中间,不一定要用DeviceSpecific,我们可以使用自定义控件来实现,比如我们可以从Label派生一个出来,然后重载OnRender
  protected override void OnRender(System.Web.UI.HtmlTextWriter writer)
  {
   if(this.MobilePage.Device.PreferredRenderingType == "xhtml-mp" ||
    this.MobilePage.Device.PreferredRenderingType == "wml11")
   {
    writer.WriteBeginTag("anchor");
    writer.Write(" title=\"" + this.title + "\">" + this.Text);
    writer.WriteBeginTag("prev");
    writer.WriteEndTag("prev");
    writer.WriteEndTag("anchor");
   }
   else
    base.OnRender(writer);
  }
然后将这个控件拖到Form中就可以实现了