asp畫中畫廣告插入在每篇文章中的實(shí)現(xiàn)方法
盡管很多人給出了給每篇文章加上畫中畫廣告的方法,但是這些所謂的方法,都不能真正地實(shí)現(xiàn)文字環(huán)繞在廣告周圍的“畫中畫”效果,只能左對(duì)其或者右對(duì)齊。現(xiàn)在要討論的這個(gè)方法才能真正實(shí)現(xiàn)像新浪網(wǎng)、搜狐網(wǎng)那樣的畫中畫廣告效果。
首先說(shuō)一下錯(cuò)誤的div+CSS方法,希望大家別被誤導(dǎo):
<div id="outer" style="float:left;"> <div id="inner" style="float:left;margin:0;width:200px;height:200px;"></div> 文字內(nèi)容 </div>
上面只能算作是左對(duì)齊的效果。還有很多借助表格或者iframe來(lái)實(shí)現(xiàn)的,也不外乎如此。
那么,怎么才能真正實(shí)現(xiàn)在每篇文章中批量添加畫中畫廣告的效果呢?可以采用截取字段來(lái)進(jìn)行,有兩段代碼。
第一段是分析文章內(nèi)容字?jǐn)?shù),然后插入廣告的代碼:
Dim LeftContent,MidAdContent,RightContent,ModifyContent,headlen,tempStr,headAdStr,tailAdStr ''截取合適數(shù)量的字符串 if len(ArticleContent)<320 then headlen=200 else headlen=320 end if tempStr=ArticleContent LeftContent=InterceptString(tempStr,headlen) '獲得截取的文字內(nèi)容 RightContent=Right(ArticleContent,Len(ArticleContent)-Len(LeftContent)) ModifyContent=LeftContent &"<div style=""float:left;""><script language=""javascript"" src=""http://www.eryi.org/ad.js""></script></div>"& RightContent
上面是通過(guò)DIV+JS 來(lái)插入廣告的,廣告代碼放在ad.js文件中,也可以通過(guò)table+JS 或者直接用iframe的方式來(lái)插入。不管以那種方式,都必須設(shè)置其屬性為左對(duì)齊或右對(duì)齊,這樣才能保證為止環(huán)繞在廣告周圍。
接下的第二段就是畫中畫廣告代碼的判斷了。
Function InterceptString(txt,length) Dim x,y,ii,c,ischines,isascii,tempStr txt=trim(txt) x = len(txt) y = 0 if x >= 1 then for ii = 1 to x c=asc(mid(txt,ii,1)) if c< 0 or c >255 then '說(shuō)明是一個(gè)中文字符 y = y + 2 ischines=1 isascii=0 else '說(shuō)明是一個(gè)ascii碼 y = y + 1 ischines=0 isascii=1 end if '如果長(zhǎng)度已經(jīng)大于定義子字符串長(zhǎng)度,就判斷是否包含敏感字符串是否分開(kāi) if y >= length then if ischines=1 and StrCount(left(trim(txt),ii),"<a")=StrCount(left(trim(txt),ii),"</a>") then txt = left(trim(txt),ii) '"字符串限長(zhǎng) exit for else if isascii=1 then x=x+1 end if end if next InterceptString = txt else InterceptString = "" end if End Function '判斷字符串出現(xiàn)的次數(shù) Function StrCount(Str,SubStr) Dim iStrCount Dim iStrStart Dim iTemp iStrCount = 0 iStrStart = 1 iTemp = 0 Str=LCase(Str) SubStr=LCase(SubStr) Do While iStrStart < Len(Str) iTemp = Instr(iStrStart,Str,SubStr,vbTextCompare) If iTemp <=0 Then iStrStart = Len(Str) Else iStrStart = iTemp + Len(SubStr) iStrCount = iStrCount + 1 End If Loop StrCount = iStrCount End Function
以新云網(wǎng)站管理系統(tǒng)為例。首先找到生長(zhǎng)靜態(tài)文章頁(yè)面的代碼文件/inc/NewsChannel.asp (其它CMS與此類似),在第248行 HtmlContent = Replace(HtmlContent, "{$ArticleContent}", ArticleContent) 的前面插入第一段代碼,在頁(yè)面中的適當(dāng)為止插入第二段代碼,然后將該行中的ArticleContent 改為ModifyContent 即可。
相關(guān)文章
asp下用replace非正則實(shí)現(xiàn)代碼運(yùn)行功能的代碼
asp下用replace非正則實(shí)現(xiàn)代碼運(yùn)行功能的代碼...2007-09-09常用ASP函數(shù)集【經(jīng)驗(yàn)才是最重要的】
常用ASP函數(shù)集【經(jīng)驗(yàn)才是最重要的】...2007-01-01asp在服務(wù)器把 XML 轉(zhuǎn)換為 XHTML的實(shí)現(xiàn)代碼
asp在服務(wù)器把 XML 轉(zhuǎn)換為 XHTML的實(shí)現(xiàn)代碼,需要的朋友可以參考下。2011-11-11C語(yǔ)言數(shù)組添加和刪除元素的實(shí)現(xiàn)
這篇文章主要介紹了C語(yǔ)言數(shù)組添加和刪除元素的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-02-02asp中設(shè)置session過(guò)期時(shí)間方法總結(jié)
asp中默認(rèn)session過(guò)期時(shí)間為20分鐘,很多情況下不夠,今天有客戶要求很多就要重新登錄了,所以準(zhǔn)備了這篇文章,方便需要的朋友2012-09-09asp中利用CSW中文分詞組件來(lái)實(shí)現(xiàn)自己網(wǎng)站的內(nèi)容關(guān)鍵詞自動(dòng)提取
asp中利用CSW中文分詞組件來(lái)實(shí)現(xiàn)自己網(wǎng)站的內(nèi)容關(guān)鍵詞自動(dòng)提取...2007-03-03