前端開發總結

来源:http://www.cnblogs.com/AndroidJotting/archive/2016/11/19/6081276.html
-Advertisement-
Play Games

好久沒有更新博客了,自從大學畢業整個人好像剛從監獄放出來似的,被外面的花花世界迷暈了,整天都是上班,再也沒有熬夜敲代碼,好久沒有對自己的學習進行總結了,趁著周末的時光總結一下這5個月來自己在前端路上裸奔的這段日子。原本大學畢業打算找個JAVA方向的或Android開發的工作,真是歲月弄人,最後來到了 ...


  好久沒有更新博客了,自從大學畢業整個人好像剛從監獄放出來似的,被外面的花花世界迷暈了,整天都是上班,再也沒有熬夜敲代碼,好久沒有對自己的學習進行總結了,趁著周末的時光總結一下這5個月來自己在前端路上裸奔的這段日子。原本大學畢業打算找個JAVA方向的或Android開發的工作,真是歲月弄人,最後來到了一家做藝術品交易的網站,網站後臺用的是.NET,只好在前端的路上裸奔了,跌進無數坑,一次次爬起,今天就一起看看我這些天遇到的各種坑,與君共勉。

  首先前端開發就繞不開javascript和css,當然還有jQuery和ajax,接下來我們就圍繞這三點一起來學習一下。

  第一點我們就從ajax來一起聊聊,說實話第一次用ajax還是挺感覺複雜的,經常聽別人說前端提交用非同步呀,那是就感覺很牛的樣子,現在看來當初是如何的天真,下麵就和大家一起回憶一下ajax非同步提交的知識。

var ajaxPara = "ThisType=" + thisType + "&HomeDiyTypeCode=" + HomeDiyTypeCode;//請求數據
        $.ajax({
            type: "POST",
            url: "/Search/GetData",//請求地址
            data: ajaxPara,
            dataType: "json",
            beforeSend: function() {
                $("#wrap").empty();
                $("#wrap").append('<img src="/Img/loading_horizontal.gif" />');
            },
            success: function(data) {//成功返回
                $("#wrap").empty();
                if (undefined != data && data !== "") {
                    var jsonObjs = eval(data);//將返回結果轉為jsonObject對象
                    pageCount = jsonObjs[0].ClickCount;
                  
                } else {
                    $("#wrap").html("此分類下暫未上傳藝術品");
                }
            },

            complete: function() {
                window.setTimeout(function() {
                    waterFall("wrap");
                    requestStatus = 2; //請求完成
                }, 300);
            }
        });

  是不是很簡單,就這樣簡單的幾句話我們就可以完成非同步提交數據,剛下坑的就別繼續了,可以上岸了。

  下麵我們來一起看一些css的相關屬性,比如如何使元素單行顯示、如何在滑鼠經過時變換樣式、如何讓圖片元素不變型居中顯示等等

行元素當行顯示

overflow: hidden;
text-overflow:ellipsis;
white-space: nowrap;

  2、行業指定行數顯示

display: -webkit-box;
-webkit-box-orient: vertical;
-webkit-line-clamp: 3;
overflow: hidden;

  3、滑鼠事件

.span{color:blue;}
.span:hover{color:red;}

ul li .span{color:blue;}
ul li:hover .span{color:red;}

  4、孩子選擇器

ul li:first-child{border:1px solid #a00;}
ul li:nth-child(2){border:1px solid #0a0;}
ul li:nth-last-child(2){border:1px solid #aa0;}
ul li:nth-child(2n + 1){border:1px solid #aaa;}
ul li:nth-last-child(2n + 1){border:1px solid #0aa;}
ul li:last-child{border:1px solid #00a;}

  5、偽元素(after/before)

h1:before{content:url(logo.gif);}
h1:after{content:url(logo.gif);}

  6、圖片不變型居中顯示

<style>
.father{width:200px;height:200px;line-height:200px;text-align:center;}
.father img{max-width:200px;max-height:200px;vertical-align: middle;}
</style>
<div class="father">
    <img src="" /> 
</div>

  暫時總結到這裡,後續繼續補充,如果感興趣,請持續關註。

  下麵一起聊聊javascript和jQuery,之前沒有怎麼用過jQuery,現在經過這些日子的不斷學習,越來越對jQuery感興趣,真是太方便了,jQuery是對javascript的封裝,使用時只要導入jQuery的依賴文件就Ok了,下麵就一起簡單回憶一下經常使用的一些用法。

  1、頁面載入完畢執行

function myfun()
{
    alert("this window.onload");
}
/*用window.onload調用myfun()*/
window.onload=myfun;//不要括弧

  2、打開頁面

window.location.href="http://www.cnblogs.com/AndroidJotting/"; //在同當前視窗中打開視窗
window.open("http://www.cnblogs.com/AndroidJotting/");//在另外新建視窗中打開視窗

  3、獲取屏幕屬性

網頁可見區域寬:document.body.clientWidth 
網頁可見區域高:document.body.clientHeight 
網頁可見區域寬:document.body.offsetWidth (包括邊線的寬) 
網頁可見區域高:document.body.offsetHeight (包括邊線的寬) 
網頁正文全文寬:document.body.scrollWidth 
網頁正文全文高:document.body.scrollHeight 
網頁被捲去的高:document.body.scrollTop 
網頁被捲去的左:document.body.scrollLeft 
網頁正文部分上:window.screenTop 
網頁正文部分左:window.screenLeft 
屏幕解析度的高:window.screen.height 
屏幕解析度的寬:window.screen.width 
屏幕可用工作區高度:window.screen.availHeight 
屏幕可用工作區寬度:window.screen.availWidth 

  4、HTML精確定位:scrollLeft,scrollWidth,clientWidth,offsetWidth 

scrollHeight: 獲取對象的滾動高度。 
scrollLeft:設置或獲取位於對象左邊界和視窗中目前可見內容的最左端之間的距離 
scrollTop:設置或獲取位於對象最頂端和視窗中可見內容的最頂端之間的距離 
scrollWidth:獲取對象的滾動寬度 
offsetHeight:獲取對象相對於版面或由父坐標 offsetParent 屬性指定的父坐標的高度 
offsetLeft:獲取對象相對於版面或由 offsetParent 屬性指定的父坐標的計算左側位置 
offsetTop:獲取對象相對於版面或由 offsetTop 屬性指定的父坐標的計算頂端位置 
event.clientX 相對文檔的水平座標 
event.clientY 相對文檔的垂直座標 
event.offsetX 相對容器的水平坐標 
event.offsetY 相對容器的垂直坐標 
document.documentElement.scrollTop 垂直方向滾動的值 
event.clientX+document.documentElement.scrollTop 相對文檔的水平座標+垂直方向滾動的量 

  5、頁面頂部浮動

//商品大類浮動
        window.onscroll = function () {//滾輪事件
            var top = window.pageYOffset || document.documentElement.scrollTop || document.body.scrollTop;//滾輪滾動的距離
            var node = document.getElementById('float-search');//變化的菜單模塊
            if (top >= 600) {//就是滾動條滾動到600px位置,顯示菜單,並且可以修改它的樣式。
                if (node.getAttribute("rel") != 1) {
                    node.style.display = "block";
                    node.setAttribute("rel", "1");
                    $("#float-search").animate({opacity:"0.98" }, 1000);
                }
            } else {//當滑鼠滾動回初始位子樣式變回。
                if (node.getAttribute("rel") != 0) {
                    node.setAttribute("rel", "0");
                    $("#float-search").animate({ opacity: "0" }, 1000, function () {
                        node.style.display = "none"
                    });
                }
            }
        }

  未完待續......

  暫時就先聊到這裡,要睡覺嘍,明天接著總結,感興趣的請持續關註。

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • spider有一個配置文件spider.xml,為xml格式,spider.xml採用DTD進行管理,用於管理spider的所有特性、路由、高可用等。 配置文件支持三種不同的方式進行指定: 1、 通過環境變數指定。SPIDER_CONFIG環境變數指定spider啟動文件所在的位置。 2、 通過ja ...
  • 2016.11.19 周六,我們在 北航參加了《GDG 谷歌開發者大會》,在web專場,聆聽了谷歌公司的與會專家的技術分享。 中午免費的午餐,下午精美的下午茶,還有精湛的技術,都是我們隊谷歌公司刮目相看。 web場分享的主題主要有下麵的幾個: 1)深度學習 TensorFlow 2)http 2協議 ...
  • 今天來回顧鞏固“韓信點兵” 首先:我們來看下其來源:在一千多年前的《孫子算經》中,有這樣一道算術題:“今有物不知其數,三三數之剩二,五五數之剩三,七七數之剩二,問物幾何?”按照今天的話來說:一個數除以3餘2,除以5餘3,除以7餘2,求這個數。這樣的問題,也有人稱為“韓信點兵”。 本人因是學java出 ...
  • 最近遇到一個問題, 執行腳本,腳本調用 一個命令,命令(deamon)是一個守護進程,為了調試,取消了守護進程模式。導致命令後邊的其他命令(echo "456")都無法執行。 deamon -d 是以守護進程模式啟動;deamon -x 是以非守護進程模式啟動(監控進程,死迴圈),stdout和st ...
  • spider RPC 特性介紹 spider RPC 性能測試 spider RPC 入門指南 spider RPC 配置文件參考 spider RPC需求來源 spider RPC的需求源於作者所在公司佈局證券金融服務行業某細分領域2B saas服務平臺的需要,以儘可能達到高可靠性、最小化單點影響 ...
  • 本部分將介紹使用spider RPC開發分散式應用的客戶端和服務端。 spider RPC中間件基於J2SE 8開發,因此需要確保伺服器上安裝了JDK 8及以上版本,不依賴於任何額外需要獨立安裝和配置的依賴程式。 註:spider RPC 1.0.1版本之前基於JDK 1.7開發,最後改為了使用JD ...
  • JS中的event 對象詳解 JS的event對象 Event屬性和方法:1. type:事件的類型,如onlick中的click;2. srcElement/target:事件源,就是發生事件的元素;3. button:聲明被按下的滑鼠鍵,整數,1代表左鍵,2代表右鍵,4代表中鍵,如果按下多個鍵, ...
  • 左右定寬,中間自適應,實現三列佈局 今天想說的是一個左右定寬,中間自適應,實現三列佈局,我也總結了以下,主要有以下幾種: 廢話不多說,直接上代碼: 第一種:float 第二種:BFC 第三種:雙飛翼佈局 第四種:flex ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...