Warning: error_log(/data/www/wwwroot/hmttv.cn/caches/error_log.php): failed to open stream: Permission denied in /data/www/wwwroot/hmttv.cn/phpcms/libs/functions/global.func.php on line 537 Warning: error_log(/data/www/wwwroot/hmttv.cn/caches/error_log.php): failed to open stream: Permission denied in /data/www/wwwroot/hmttv.cn/phpcms/libs/functions/global.func.php on line 537 国产成人精品一区二区,欧美一区2区三区3区公司,日本大片免aaa费观看视频

          整合營銷服務(wù)商

          電腦端+手機(jī)端+微信端=數(shù)據(jù)同步管理

          免費(fèi)咨詢熱線:

          前端開發(fā)之CSS圖片水平、垂直居中顯示

          過前端開發(fā)的朋友都知道,要使文字在一個(gè)div容器垂直居中顯示是很簡(jiǎn)單的事,但是如果是要讓一張圖片在div容器中垂直顯示那就有點(diǎn)傷腦筋了,因?yàn)閳D片是個(gè)置換元素,有些特殊的特性,對(duì)于前端開發(fā)的大牛來說還好,解決方法有很多,比如什么利用js啊之類的,但是這些對(duì)于初學(xué)者來說就有些難度了,今天小編就把自己平時(shí)在項(xiàng)目中用的方法分享給大家,給大家一個(gè)參考。

          其實(shí)小編用的方法也不是什么很高端的技術(shù),算是最low的方法吧,但是很實(shí)用,能兼容各種瀏覽器,為了演示,小編直接從某寶商家店鋪里拿了一張商品圖來做演示,因?yàn)樯唐穲D都是高清無碼的,且還很大,所以我們?cè)贑SS中把圖片的高度設(shè)置為200px,div容器的高度為300px,完整的代碼如下:

          最終的運(yùn)行效果如下圖:

          可以看到,這個(gè)圖片在div中水平、垂直都是在正中間,是不是很完美。這個(gè)原理也很簡(jiǎn)單,就是在div容器中加了個(gè) <i> 標(biāo)簽并把它的 display 屬性設(shè)置為 inline-block(行內(nèi)塊元素),讓它去撐開div容器的高度,再把圖片的 vertical-align 屬性設(shè)置為 middle 就可以垂直居中了,當(dāng)然這只是個(gè)演示,大家在實(shí)際的項(xiàng)目中可以利用 max-width、min-width、max-height、min-height 等屬性讓圖片根據(jù)需要自適應(yīng),以達(dá)到想要的效果。

          當(dāng)然解決方法還有很多種,具體用什么方法需根據(jù)自身頁面布局去權(quán)衡,總之沒有最好的,只有最適合的,如果你有更好的方法也可以告訴小編哦,一起交流方法,共同進(jìn)步。

          lexbox

          通常首選方法是使用flexbox居中內(nèi)容。只需三行代碼即可:display:flex,然后使用 align-items:center justify-content:center 將子元素垂直和水平居中。

          如下代碼:

          html:

          <div class="flexbox-centering">
            <div>Centered content.</div>
          </div>

          css:

          .flexbox-centering {
            display: flex;
            justify-content: center;
            align-items: center;
            height: 100px;
          }

          Grid

          使用grid(網(wǎng)格)與flexbox非常相似,也是一種常見的技術(shù),尤其是布局中已經(jīng)使用網(wǎng)格的情況下。與前一種flexbox技術(shù)的唯一區(qū)別是它顯示為柵格。

          如下代碼:

          html:

          <div class="grid-centering">
            <div class="child">Centered content.</div>
          </div>

          css:

          上效果圖:

          這是一個(gè)用ext3.2.0、js、html、css寫的一個(gè)還算好看的登錄界面。

          源代碼已上傳,下載地址請(qǐng)點(diǎn)擊:點(diǎn)擊打開鏈接

          其主要難點(diǎn)在如何使用extjs來畫一個(gè)界面,接下來我們就主要看一下其中的html和js吧:


          1. <!DOCTYPE html>
          2. <html lang="en">
          3. <head>
          4. <meta charset="UTF-8">
          5. <title>登錄界面</title>
          6. <link rel="stylesheet" type="text/css" href="ext3.2.0/resources/css/ext-all.css"/>
          7. <script type="text/javascript" src="ext3.2.0/adapter/ext/ext-base.js"></script>
          8. <script type="text/javascript" src="ext3.2.0/ext-all.js"></script>
          9. <script type="text/javascript" src="login.js"></script>
          10. <script type="text/javascript" src="loginToDo.js"></script>
          11. <link rel="stylesheet" type="text/css" href="login.css"/>
          12. </head>
          13. <body onkeydown="keyLogin(event);">
          14. </body>
          15. </html>

          這里面主要是導(dǎo)入頁面所需的js和css文件,當(dāng)然還有一個(gè)亮點(diǎn)就是body標(biāo)簽上的 onkeydown事件屬性,主要用于監(jiān)聽鍵盤實(shí)現(xiàn)我們js中的enter鍵提交功能。然后看一下extjs的語言風(fēng)格吧:


          1. Ext.onReady(function () {
          2. // 創(chuàng)建“登錄”面板
          3. var loginPanel = new Ext.Panel({
          4. // 設(shè)置面板的位置、寬高、樣式
          5. // 注意:此處我用的是相對(duì)布局relative(用于比較兩者的區(qū)別)
          6. id: 'loginPan',
          7. x: 363,
          8. y: 0,
          9. width: 396,
          10. height: 480,
          11. baseCls: '',
          12. defaults: {
          13. border: false
          14. },
          15. // 添加面板里面的物品
          16. items: [
          17. {
          18. // 第一件:logo圖
          19. id: 'loginLogo',
          20. height: 160,
          21. frame: false,
          22. bodyStyle: 'padding-top:10px',
          23. html: '<img src="images/fly_icon.png">'
          24. },
          25. {
          26. // 第二件:登錄的表單
          27. id: 'loginForm',
          28. defaultType: 'textfield',
          29. frame: false,
          30. defaults: {
          31. allowBlank: false
          32. },
          33. // 添加表單里面的物品:兩個(gè)輸入框
          34. items: [
          35. {
          36. id: "username",
          37. cls: "text_field",
          38. inoutType: 'text',
          39. width: 330,
          40. height: 28,
          41. blankText: '賬號(hào)不能為空',
          42. emptyText: '請(qǐng)輸入賬號(hào)',
          43. },
          44. {
          45. id: "password",
          46. cls: "text_field",
          47. inputType: 'password',
          48. width: 330,
          49. height: 28,
          50. emptyText: '請(qǐng)輸入密碼',
          51. blankText: '密碼不能為空',
          52. }]
          53. },
          54. {
          55. // 第三件:忘記密碼
          56. id: 'loginForget',
          57. html: "<a href='forget_pwd.html' target='_blank'>忘記密碼?</a>",
          58. },
          59. {
          60. // 第四件:登錄按鈕
          61. id: 'loginBtn',
          62. html: '<button id="btn_login">馬上登錄</button>',
          63. }
          64. ],
          65. });
          66. // 創(chuàng)建“注冊(cè)”面板
          67. var registerPanel = new Ext.Panel({
          68. // 設(shè)置面板的位置、寬高、樣式
          69. // 注意:此處我用的是絕對(duì)布局absolute(用于比較兩者的區(qū)別)
          70. id: 'registerPan',
          71. x: 0,
          72. y: 46,
          73. width: 800,
          74. height: 389,
          75. baseCls: '',
          76. layout: 'absolute',
          77. defaults: {
          78. border: false
          79. },
          80. // 添加面板里面的物品
          81. items: [
          82. {
          83. // 第一件:標(biāo)題
          84. id: 'registerTitleLabel',
          85. xtype: 'label',
          86. x: 47,
          87. y: 50,
          88. text: '還沒有賬號(hào)?',
          89. }, {
          90. // 第二件:正文
          91. id: 'registerContentLabel',
          92. xtype: 'label',
          93. x: 47,
          94. y: 135,
          95. text: '這是在注冊(cè)面板下面的正文內(nèi)容。里面的內(nèi)容可以隨便寫,比如當(dāng)前我們?cè)僖粋€(gè)窗口下面建立了兩個(gè)面板。而兩個(gè)面板的布局是分別用相對(duì)布局和絕對(duì)布局來實(shí)現(xiàn)的。相比較而言,我覺得用絕對(duì)布局會(huì)簡(jiǎn)單粗暴,更直接,更方便。總之,你們自己體會(huì)一下吧。',
          96. }, {
          97. // 第三件:注冊(cè)按鈕
          98. id: 'registerBtn',
          99. xtype: 'button',
          100. x: 47,
          101. y: 280,
          102. html: '<button id="btn_register" >馬上注冊(cè)</button>'
          103. }],
          104. });
          105. // 創(chuàng)建窗口,從而讓內(nèi)容達(dá)到居中效果
          106. var centerWindow = new Ext.Window({
          107. baseCls: '',
          108. width: 800,
          109. height: 480,
          110. layout: 'absolute',
          111. closable: false,
          112. draggable: false,
          113. resizable: false,
          114. shadow: false,
          115. border: false,
          116. items: [registerPanel, loginPanel],
          117. });
          118. // 顯示窗口
          119. centerWindow.show();
          120. // 添加瀏覽器縮放自動(dòng)居中效果
          121. Ext.EventManager.onWindowResize(function () {
          122. centerWindow.center();
          123. });
          124. });

          這里要說的是:1、注意給屬性加標(biāo)記,能用id就用id,cls只是一個(gè)封裝過的class,和原生的class還是有區(qū)別的,比如給一個(gè)cls元素的height、padding定義樣式并不起作用。詳見:關(guān)于extjs中的cls ≠ class

          2、在ext中建議用絕對(duì)定位,由于它底層是一個(gè)個(gè)的table、div塊,如果用相對(duì)定位的話偶爾是有偏差的,所以還是絕對(duì)定位方便直接啊。

          3、window自帶居中效果,可以利用這一點(diǎn)讓元素在屏幕中居中。但是當(dāng)瀏覽器縮放的時(shí)候,這個(gè)window并不會(huì)動(dòng),每次都需要重新刷新一下才會(huì)改變一下。所以,在以上代碼的最后我們用給這個(gè)centerWindow添加了一個(gè)窗口自適應(yīng)居中的效果。


          主站蜘蛛池模板: 精品福利一区二区三| 东京热人妻无码一区二区av| 一区精品麻豆入口| 久久久无码精品国产一区| 国产成人精品视频一区| 3D动漫精品一区二区三区| 日本高清成本人视频一区| 日韩精品一区二区三区视频 | 亚洲Av永久无码精品一区二区 | 精品成人av一区二区三区| 成人区人妻精品一区二区三区| 国产精品丝袜一区二区三区 | 无码国产精品久久一区免费| 精品国产一区二区三区久久| 久99精品视频在线观看婷亚洲片国产一区一级在线 | 亚洲AV一区二区三区四区| 精品一区二区三区色花堂| 精品视频一区二区| 国产在线观看91精品一区| 精品国产一区二区三区久久影院| 国产福利一区二区三区在线观看| 国产成人AV一区二区三区无码 | 成人精品一区二区不卡视频| 亚洲AV无码一区二区三区在线| 久久一区二区三区精品| 国产激情з∠视频一区二区| 国产精品日本一区二区不卡视频| 国产色情一区二区三区在线播放| 精品久久久久中文字幕一区| 久久99精品免费一区二区| 成人免费一区二区三区| 日韩一本之道一区中文字幕| 国产自产V一区二区三区C| 日韩精品成人一区二区三区| 亚洲一区中文字幕久久| 91无码人妻精品一区二区三区L| 精品无码一区二区三区爱欲九九| 精品人妻一区二区三区浪潮在线| 国产成人一区二区三中文| 日本福利一区二区| 精品一区二区三区在线观看 |