整合營銷服務商

          電腦端+手機端+微信端=數據同步管理

          免費咨詢熱線:

          西門子PLCS7-1200用戶自定義Web頁面制作

          門子PLC S7-1200有個web頁面發布的功能,這個功能好像很少有人提及它的使用,我也只是偶爾用來監控一下PLC變量,因為打開TIA14確實有點慢。

          但是這個功能**不是什么雞肋,因為它可以發布用戶自定義的頁面,而且頁面可以加載javas cript,這就使得它的功能跟火箭一樣一飛沖天了,不過SIEMENS的**文檔也說了,*好不要靠這個功能來代替專業的HMI軟件,畢竟它的實時性和安全性還是有待斟酌的。

          但是在產品調試階段還有測試階段,這個功能確實很值得一用,因為它很方便實現也很容易讓不懂PLC系統的測試人員無門檻上手,畢竟打開瀏覽器這個操作人人都會。

          實現起來很簡單,網上的英文文檔也很多,介紹的很詳細,所以這里就不詳細說怎么實現了,只是說一說基于主流的CSS框架來使頁面制作的更容易和更美觀一些,還有就是在實際編寫過程中遇到的一些問題


          框架結構

          在實際開始進行web功能編寫前,需要先規劃一下需要展示幾個頁面和頁面的布局,這里介紹一個網站layoutit,這個完全可視化的網站可以進行拖放操作實現網頁布局,布局后的html代碼可以下載下來直接使用,使用的CSS框架是主流的bootstrap,可以說頁面的美觀程度完全不用操心,**主流,下面是我用它生成的一個網頁結構,之后下載到PLC后,瀏覽器中打開的樣子.


          放入變量

          網頁結構完成后,就可以放入PLC的變量了,這里其實沒什么特別要說的,變量是通過在整個html文件開頭通過AWP進行所謂的聲明,之后在網頁中進行使用

          從PLC進行讀操作的變量通過

          <!--AWP_Out_Variable Name='"此處填寫變量名"'-->

          從PLC進行寫操作的變量通過

          <!--AWP_In_Variable Name='"此處填寫變量名"'-->

          這里要注意引號的使用,如果是內存變量M,或者Q,I之類的輸入輸出變量,就是通過單引號外加雙引號將它括起來,像這樣

          ‘“此處填寫變量名”‘

          但是如果是DB塊的變量,就需要像這樣

          ‘“DataBloack名稱”.變量名稱’

          實際的使用中,無非也就幾種操作,

          • 網頁端按下按鈕控制PLC的變量
          • 在網頁端顯示PLC的某個變量
          • 網頁端輸入某個數字到PLC內某個變量

          基本這三種操作就能實現大部分功能,其他的諸如枚舉變量,數組顯示我都很少用到,大家自己研究吧


          網頁端按下按鈕控制PLC的變量

          這個功能通過表單的POST方法實現

          <form method="POST" action="" align="right">
            <input type="submit" value="開始測試" class="btn btn-primary btn-sm">
            <input type="hidden" name='"AI_TEST_Start_Stop"' value="1"></form>

          第1,2,4行可以原封不動的敲進去,因為沒有任何功能性的東西,都是一些顯示和樣式,只有第三行比較重要,其中name后面是PLC的變量名,value是給這個變量寫入1,這個就實現了按下按鈕,這個變量置1的操作,那怎么置0呢,把value改成0就行了。


          在網頁端顯示PLC的某個變量

          這個功能*簡單,在需要顯示變量的地方插入代碼

          <td class="font-weight-bold">:="200asModbusMaster_DB".ModbusMaster_6:</td>

          兩邊尖括號的東西可以忽略,只要注意尖括號內部的代碼就行,這是顯示的是DB塊變量,顯示變量的時候可以不需要單引號,但是兩端都要有冒號。


          網頁端輸入某個數字到PLC內某個變量

          這個和按下按鈕控制變量的實現機制是一樣的,只不過需要有個輸入框

          <form method="POST" action="">
            <input type="text" name='"1200asModbusSlave_DB".ModbusSlave_7'>
            <input type="submit" class="btn btn-success btn-sm" value="輸入700"></form>

          可以看到第2行type是text,這就是那個輸入框,這里面的數值是賦給name的,name后面的變量就是PLC里面的變量,這里需要有單引號,第三行是通過一個按鈕實現提交動作,也就是按下按鈕后,1200asModbusSlave_DB”.ModbusSlave_7就寫入你輸入的那個值了


          圖形顯示

          再來說一種,有些時候希望一個Bool變量不是單純的在網頁端顯示1或者0,而是能用圖形來進行顯示,這個也是可以實現的

          <img src='Images/Lamp0:="TestFinished":.png' />

          這個HTML代碼正常的樣子其實是這樣的

          <img src='Images/Lamp00.png' />或者<img src='Images/Lamp01.png' />

          發現一些端倪了吧,其實就是用Bool變量來替換Lamp0x后面的這個x,0的時候就是Lamp00.png,1的時候就是Lamp01.png,這兩張圖片是這樣的

          *后是這個樣子的

          TML是制作網頁的基礎,我們在網站建設中談論的靜態網頁就是基于HTML的網頁。

          早期的網頁直接用HTML代碼編寫,但現在有許多智能網頁制作軟件(常用的如frontpage,dream weaver等)通常不需要手動編寫代碼,而是由這些軟件自動生成。雖然不需要自己寫,但是理解HTML代碼仍然是非常重要的。

          了解HTML是什么?它是學習網站建設的重要技術基礎知識

          下面我們自己可以動手創建一個非常簡單的網頁,首先我們讓計算機顯示擴展,方法是打開我的電腦,然后現在欄目工具》文件夾選項》查看》高級設置中找到《隱藏已知文件類型的擴展名》將其不勾選,并單擊“應用”以確認設置。然后在桌面上創建一個新的TXT文件,將此文件命名為“xxx.html”(擴展名也可以是htm),這樣你就可以用瀏覽器打開它,你就會看到自己制作的最簡單的頁面。

          進一步的簡單理解什么是html?

          html是一種超文本標記語言,即html(hypertext markup language),是一種用來描述網絡文檔的標記語言。在頁面的開頭和結尾使用<html></html>標簽。

          總結:

          1)HTML是我們常說的靜態網頁;

          2)HTML是以Html或htm為擴展名的文件;

          3)HTML某些標簽代碼規則,讓內容在瀏覽器中呈現出我們所需要的樣式;

          4)HTML可以使用記事本創建,并以.html或.htm為擴展名保存。

          html文件中的代碼由具有一定的規則規律標簽與內容組成。以指定的HTML結構和內容形成完整的html文件。我們可以直接使用瀏覽器來打開,查看網頁效果。

          如果您想在瀏覽器中顯示各式各樣的網頁,我們就需要html文件(HTML基本結構+內容+標簽)和css文件(css樣式)來實現我們需要的漂亮網頁。

          HTML基礎學習教程

          動力節點老杜講解的html學習教程,非常詳細全面,完全適合小白入門

          內容:講解了HTML基礎語法、HTML概述、W3C概述、B/S架構系統原理、table、背景色與背景圖片、超鏈接、列表、表單、框架等知識點。

          通過html教程的學習之后,不但可以開發基本的網頁,還可以看懂別人編寫的HTML頁面。

          HTML完整資料下載:
          http://www.bjpowernode.com/?toutiaoweb.chai

          HTML課程目錄

          1.HTML教程:課程內容概述

          2.HTML教程:BS結構介紹

          3.HTML教程:軟件環境準備

          4.HTML教程:HTML概述

          5.HTML教程:我的第一個HTML

          6.HTML教程:HTML的基本標簽

          7.HTML教程:HTML的實體符號

          8.HTML教程:HTML的表格

          9.HTML教程:HTML的單元格合并1

          10.HTML教程:HTML的單元格合并2

          11.HTML教程:thead tbody tfoot

          12.HTML教程:背景色和背景圖片

          13.HTML教程:HTML圖片img標簽

          14.HTML教程:HTML超鏈接

          15.HTML教程:超鏈接的作用-request和response的概念

          16.HTML教程:HTML列表

          17.HTML教程:form表單初步

          18.HTML教程:用戶注冊表單的實現

          19.HTML教程:下拉列表支持多選

          20.HTML教程:form的file控件

          21.HTML教程:隱藏域hidden控件

          22.HTML教程:隱藏域hidden控件2

          23.HTML教程:readonly和disabled

          24.HTML教程:控件的maxlength屬性

          25.HTML教程:HTML文檔中節點的id屬性

          26.HTML教程:div和span在網頁中的應用

          Low了,網頁居然還用這么老掉牙的特效!弄個粗體字,下劃線就是突出重點了?真是一股濃濃的鄉村風撲面而來;弄個圖在頁面飄來飄去就是動畫效果了,你要這么認為的話那我只能保持沉默了。在HTML5占領著整個互聯網之時,想透過網頁抓住所有人的眼球,因循守舊是行不通的。因此,有你不能不知道的HTML常用代碼。只有熟悉掌握了常用的HTML代碼,你才能在編寫網頁的時候做到行云流水,用處處流露著細膩和創意的動效細節打動所有人。

          在這里還是要說一下我自己建的前端JavaScript學習交流群:574462090,不管你是小白還是大牛,小編我都挺歡迎,小白嘛,多問點問題也就學好了,不定期分享干貨,包括最新的2017年前端學習資料,歡迎初學和進階中的小伙伴。

          html代碼大全:結構性定義

          文件類型<HTML></HTML> (放在檔案的開頭與結尾)

          文件主題<TITLE></TITLE> (必須放在「文頭」區塊內)

          文頭<HEAD></HEAD> (描述性資料,像是「主題」)

          文體<BODY></BODY> (文件本體)

          標題<H?></H?> (從1到6,有六層選擇)

          標題的對齊 <H?ALIGN=LEFT|CENTER|RIGHT></H?>

          區分<DIV></DIV>

          區分的對齊 <DIVALIGN=LEFT|RIGHT|CENTER|JUSTIFY></DIV>

          引文區塊<BLOCKQUOTE></BLOCKQUOTE> (通常會內縮)

          強調<EM></EM> (通常會以斜體顯示)

          特別強調<STRONG></STRONG> (通常會以加粗顯示)

          引文<CITE></CITE> (通常會以斜體顯示)

          碼<CODE></CODE> (顯示原始碼之用)

          樣本<SAMP></SAMP>

          鍵盤輸入<KBD></KBD>

          變數<VAR></VAR>

          定義<DFN></DFN> (有些瀏覽器不提供)

          地址 <ADDRESS></ADDRESS>

          大字<BIG></BIG>

          小字<SMALL></SMALL>

          與外觀相關的標簽(作者自訂的表現方式)

          加粗<B></B>

          斜體<I></I>

          底線<U></U> (尚有些瀏覽器不提供)

          刪除線<S></S> (尚有些瀏覽器不提供)

          下標<SUB></SUB>

          上標<SUP></SUP>

          打字機體<TT></TT> (用單空格字型顯示)

          預定格式<PRE></PRE> (保留文件中空格的大小)

          預定格式的寬度<PRE WIDTH=?></PRE>(以字元計算)

          向中看齊<CENTER></CENTER> (文字與圖片都可以)

          閃耀<BLINK></BLINK> (有史以來最被嘲弄的標簽)

          字體大小 <FONTSIZE=?></FONT>(從1到7)

          改變字體大小 <FONTSIZE=+|-?></FONT>

          基本字體大小 <BASEFONTSIZE=?> (從1到7; 內定為3)

          字體顏色 <FONTCOLOR="#$$"></FONT>($$為顏色代碼)

          2

          html代碼大全:修改頁面的實用性HTML代碼

          1)貼圖:<img src="圖片地址">

          2)加入連接:<a href="所要連接的相關地址">寫上你想寫的字</a>

          3)在新窗口打開連接:<a href="相關地址" target="_blank">寫上要寫的字</a>

          4)移動字體(走馬燈):<marquee>寫上你想寫的字</marquee>

          5)字體加粗:<b>寫上你想寫的字</b>

          6)字體斜體:<i>寫上你想寫的字</i>

          7)字體下劃線: <u>寫上你想寫的字</u>

          8)字體刪除線: <s>寫上你想寫的字</s>

          9)字體加大: <big>寫上你想寫的字</big>

          10)字體控制大小:<h1>寫上你想寫的字</h1> (其中字體大小可從h1-h5,h1最大,h5最小)

          11)更改字體顏色:<font color="#value">寫上你想寫的字</font>(其中value值在000000與ffffff(16位進制)之間

          12)消除連接的下劃線:<a href="相關地址" style="text-decoration:none">寫上你想寫的字</a>

          13)貼音樂:<embed src="音樂地址" width="寬度" height="高度" autostart=false>

          14)貼flash: <embed src="flash地址" width="寬度" height="高度">

          15)貼影視文件:<img dynsrc="文件地址" width="寬度" height="高度" start=mouseover>

          16)換行:<br>

          17)段落:<p>段落</p>

          18)原始文字樣式:<pre>正文</pre>

          19)換帖子背景:<body background="背景圖片地址">

          20)固定帖子背景不隨滾動條滾動:<body background="背景圖片地址" body

          bgproperties=fixed>

          21)定制帖子背景顏色:<body bgcolor="#value">(value值見10)

          22)帖子背景音樂:<bgsound="背景音樂地址" loop=infinite>

          23)貼網頁:<iframe. src="相關地址" width="寬度" height="高度"></iframe>

          3

          html代碼大全:常常會遇到的問題

          點擊關閉窗口

          <a href="javascript.:top.window.close();">點擊關閉窗口</a>!

          請問如何去掉主頁右面的滾動條?

          <body scroll="no">

          <body style="overflow-y:hidden">

          如何做到讓一個網頁自動關閉.

          <html>

          <head>

          <OBJECT id=closes type="application/x-oleobject" classid="clsid:adb880a6-d8ff-11cf-9377-00aa003b7a11">

          <param name="Command" value="Close">

          </object>

          </head>

          <body >

          這個窗口會在10秒過后自動關閉,而且不會出現提示. </body>

          如何在不刷新頁面的情況下刷新css?

          <style>

          button{ color:#000000;}

          </style>

          <button nclick=document.styleSheets[0].rules[0].style.color=‘‘‘‘red‘‘‘‘>點擊按鈕直接修改style標簽里button選擇符使按鈕改為  紅色</button>

          請問如何讓網頁自動刷新?

          在head部記入<META. HTTP-EQUIV="Refresh" c>其中20為20秒后自動刷新,你可以更改為任意值。

          如何讓頁面自動刷新?

          方法一,用refresh

          HTML 代碼片段如下:

          <head>

          <meta. http-equiv="refresh" c>

          </head>

          5表示刷新時間

          [Ctrl+A 全部選擇 提示:你可先修改部分代碼,再按運行]

          方法二,使用setTimeout控制

          <img src=/logo.gif>

          <script>

          function rl(){

          document.location.reload()

          }

          setTimeout(rl,2000)

          </SCRIPT>

          如何讓超鏈接沒有下劃線

          在源代碼中的<HEAD>…</HEAD>之間輸入如下代碼:

          <style. type="text/css"> <!--

          a { text-decoration: none}

          --> </style>

          請問如何去掉IE的上下滾動條?

          <body style=‘‘‘‘overflow:scroll;overflow-y:hidden‘‘‘‘>

          </body>

          怎樣才能把RealPlayer文件在網頁做一個試聽連接?

          <embed height=25 src=51js.rm type=audio/x-pn-realaudio-plugin width=50 autostart="false" c>

          如何用html實現瀏覽器上后退按鈕的功能?

          <a href="java script.:history.go(-1)">點擊后退</a>

          或者

          <script> history.back() </SCRIPT>

          4

          html代碼大全:你不一定知道的技巧

          16. ncontextmenu="window.event.returnValue=false" 將徹底屏蔽鼠標右鍵

            <table borderncontextmenu=return(false)><td>no</table> 可用于Table

          17. <body nselectstart="return false"> 取消選取、防止復制

          18.onpaste="return false" 不準粘貼

          19.oncopy="return false;" ncut="return false;" 防止復制

          20. <link rel="Shortcut Icon"href="favicon.ico"> IE地址欄前換成自己的圖標

          21. <link rel="Bookmark"href="favicon.ico"> 可以在收藏夾中顯示出你的圖標

          22. <inputstyle="ime-mode:disabled"> 關閉輸入法

          23. 永遠都會帶著框架

          <script. language="JavaScript"><!--

          if (window == top)top.location.href = "frames.htm"; //frames.htm為框架網頁

          // --></script>

          24. 防止被人frame.

          <SCRIPT. LANGUAGE=JAVASCRIPT><!--

          if (top.location != self.location)top.location=self.location;

          // --></SCRIPT>

          25. 網頁將不能被另存為

          <noscript><iframe.src=*.html></iframe></noscript>

          26. 查看網頁源代碼

          <input type=button value=查看網頁源代碼

          onclick="window.location = "view-source:"+"http://www.pconline.com.cn"">

          27.刪除時確認

          <a href="javascript:if(confirm("確實要刪除嗎?"))location="boos.asp? &areyou=刪除&page=1"">刪除</a>

          28.屏蔽功能鍵Shift,Alt,Ctrl

          <script>

          function look(){

          if(event.shiftKey)

          alert("禁止按Shift鍵!");//可以換成ALT CTRL

          }

          document.onkeydown=look;

          </script>

          29. 網頁不會被緩存

          <META. HTTP-EQUIV="pragma" CONTENT="no-cache">

          <META. HTTP-EQUIV="Cache-Control"CONTENT="no-cache, must-revalidate">

          <META. HTTP-EQUIV="expires"CONTENT="Wed, 26 Feb 1997 08:21:57 GMT">

          或者<META. HTTP-EQUIV="expires"CONTENT="0">

          30.怎樣讓表單沒有凹凸感?

          <input type=text style="border:1 solid #000000">

          或 <input type=text style="border-left:none;border-right:none; border -top:none; border-bottom: 1 solid#000000"></textarea>

          31.不要滾動條?

          讓豎條沒有:

          <body style="overflow:scroll;overflow-y:hidden">

          </body>

          讓橫條沒有:

          <body style="overflow:scroll;overflow-x:hidden">

          </body>

          兩個都去掉?更簡單了

          <body scroll="no">

          </body>

          32.怎樣去掉圖片鏈接點擊后,圖片周圍的虛線?

          <a href="#"nFocus="this.blur()"><img src="logo.jpg"border=0></a>

          33.電子郵件處理提交表單

          <form. name="form1"method="post" action="mailt****@***.com"enctype="text/plain">

          <input type=submit>

          </form>

          34.在打開的子窗口刷新父窗口的代碼里如何寫?

          window.opener.location.reload()

          35.如何設定打開頁面的大小

          <body nload="top.resizeTo(300,200);">

          打開頁面的位置<bodynload="top.moveBy(300,200);">

          36.在頁面中如何加入不是滿鋪的背景圖片,拉動頁面時背景圖不動

          <STYLE>

          body

          {background-image:url(logo.gif); background-repeat:no-repeat;

          background-position:center;background-attachment: fixed}

          </STYLE>

          37. 檢查一段字符串是否全由數字組成

          <script. language="Javascript"><!--

          function checkNum(str){return str.match(//D/)==null}

          alert(checkNum("1232142141"))

          alert(checkNum("123214214a1"))

          // --></script>

          38. 獲得一個窗口的大小

          document.body.clientWidth; document.body.clientHeight

          39. 怎么判斷是否是字符

          if (/[^/x00-/xff]/g.test(s)) alert("含有漢字");

          else alert("全是字符");

          40.TEXTAREA自適應文字行數的多少

          <textarea rows=1 name=s1 cols=27npropertychange="this.style.posHeight=this.scrollHeight">

          </textarea>

          41. 日期減去天數等于第二個日期

          <script. language=Javascript>

          function cc(dd,dadd)

          {

          //可以加上錯誤處理

          var a = new Date(dd)

          a = a.valueOf()

          a = a - dadd * 24 * 60 * 60 * 1000

          a = new Date(a)

          alert(a.getFullYear() + "年" + (a.getMonth() +1) + "月" + a.getDate() + "日")

          } cc("12/23/2002",2)

          </script>

          42. 選擇了哪一個Radio

          <HTML><script. language="vbscript">

          function checkme()

          for each ob in radio1

          if ob.checked then window.alert ob.value

          next

          end function

          </script><BODY>

          <INPUT name="radio1" type="radio"value="style" checked>Style.

          <INPUT name="radio1" type="radio"value="barcode">Barcode

          <INPUT type="button" value="check"nclick="checkme()">

          </BODY></HTML>

          43.腳本永不出錯

          <SCRIPT. LANGUAGE="JavaScript">

          <!-- Hide function killErrors(){return true;} window.onerror = killErrors;// -->

          </SCRIPT>

          44.ENTER鍵可以讓光標移到下一個輸入框

          <input nkeydown="if(event.keyCode==13)event.keyCode=9">

          文末再提兩點建議吧:

          1. 剛學前端JavaScript的時候,一定不要追求速成,編程不比其他傳統行業,可以快速的上手,他需要一定的代碼量積累起來,不然你追求速成很可能會車毀人亡。

          2. 這個文章到這里就說完了,想要前端學習資料的進我的群自助領取,已經上傳到群文件里了:574462090,歡迎初學和進階中的小伙伴。

          如果想看到更加系統的文章和學習方法經驗可以關注我的微信公眾號:‘前端根據地’關注后回復‘給我資料’可以領取一套完整的學習視頻


          主站蜘蛛池模板: 国产日韩精品一区二区三区| 日韩伦理一区二区| 国产成人av一区二区三区在线观看| 麻豆视传媒一区二区三区| 久久久久人妻精品一区蜜桃| 一区二区不卡久久精品| 国产美女一区二区三区| 亚洲视频一区二区| 国产精品亚洲专一区二区三区| 国产成人精品日本亚洲专一区| 成人精品一区二区三区不卡免费看 | 国产精品无码一区二区三级 | 无码人妻一区二区三区免费n鬼沢 无码人妻一区二区三区免费看 | 一区二区在线免费观看| 国产成人综合精品一区| 手机福利视频一区二区| 一区二区三区视频| 亚洲高清美女一区二区三区| 国产精品熟女一区二区| 综合久久久久久中文字幕亚洲国产国产综合一区首 | 国产在线一区二区三区| 中文字幕在线视频一区| 无码精品人妻一区| 国产在线观看91精品一区| 国模无码视频一区二区三区| 精品午夜福利无人区乱码一区| 青青青国产精品一区二区| 午夜福利国产一区二区| 日本美女一区二区三区| 成人免费视频一区| 亚洲国产老鸭窝一区二区三区 | 色狠狠AV一区二区三区| 红桃AV一区二区三区在线无码AV| 精品一区二区三区波多野结衣| 无码日韩人妻AV一区二区三区| 91在线一区二区| 国产精品 视频一区 二区三区| 日本夜爽爽一区二区三区| 精品一区精品二区制服| 精品日韩一区二区三区视频| 鲁丝片一区二区三区免费|