主頁 > 企業開發 > 11-ElementUI

11-ElementUI

2022-08-04 09:11:18 企業開發

1、Element簡介

  • Element是餓了么公司前端開發團隊提供的一套基于Vue的網站組件庫,用于快速構建網頁
  • Element提供了很多組件(組成網頁的部件)供我們使用,
  • 官方網站
    • https://element.eleme.cn/#/zh-CN

2、快速入門

2.1、將相關的element-uijs檔案拷貝至個人專案的webapp下

2.2、創建頁面,并在頁面引入Element的css、js檔案和Vue的js檔案

  • <script src="https://www.cnblogs.com/OnlyOnYourself-lzw/archive/2022/08/03/vue.js"></script>
    <script src="https://www.cnblogs.com/OnlyOnYourself-lzw/archive/2022/08/03/element-ui/lib/index.js"></script>
    <link rel="stylesheet" href="https://www.cnblogs.com/OnlyOnYourself-lzw/archive/2022/08/03/element-ui/lib/theme-chalk/index.css">
    

2.3、創建Vue核心物件

  • Element是基于Vue開發的,所以使用Element時必須要創建Vue物件

  • <script>
      new Vue({
        el:"#id值"
      })
    </script>
    

2.4、在官網中復制Element組件代碼

  • 在左邊選單欄找到Button按鈕選項,然后找到自己喜歡的按鈕樣式,點擊顯示代碼,在下面就會展示出對應的代碼,將這些代碼拷貝到我們自己的頁面即可

2.5、整體代碼如下

  • <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
    </head>
    <body>
    <div id="app">
        <el-row>
       	<el-button>默認按鈕</el-button>
          <el-button type="primary">主要按鈕</el-button>
          <el-button type="success">成功按鈕</el-button>
          <el-button type="info">資訊按鈕</el-button>
          <el-button type="warning">警告按鈕</el-button>
          <el-button type="danger">洗掉</el-button>
      </el-row>
      <el-row>
          <el-button plain>樸素按鈕</el-button>
          <el-button type="primary" plain>主要按鈕</el-button>
          <el-button type="success" plain>成功按鈕</el-button>
          <el-button type="info" plain>資訊按鈕</el-button>
          <el-button type="warning" plain>警告按鈕</el-button>
          <el-button type="danger" plain>危險按鈕</el-button>
      </el-row>
    
      <el-row>
          <el-button round>圓角按鈕</el-button>
          <el-button type="primary" round>主要按鈕</el-button>
          <el-button type="success" round>成功按鈕</el-button>
          <el-button type="info" round>資訊按鈕</el-button>
          <el-button type="warning" round>警告按鈕</el-button>
          <el-button type="danger" round>危險按鈕</el-button>
      </el-row>
    
      <el-row>
          <el-button icon="el-icon-search" circle></el-button>
          <el-button type="primary" icon="el-icon-edit" circle></el-button>
          <el-button type="success" icon="el-icon-check" circle></el-button>
          <el-button type="info" icon="el-icon-message" circle></el-button>
          <el-button type="warning" icon="el-icon-star-off" circle></el-button>
          <el-button type="danger" icon="el-icon-delete" circle></el-button>
      </el-row>
       </div>
    
      <script src="https://www.cnblogs.com/OnlyOnYourself-lzw/archive/2022/08/03/js/vue.js"></script>
    
      <script src="https://www.cnblogs.com/OnlyOnYourself-lzw/archive/2022/08/03/element-ui/lib/index.js"></script>
    
      <link rel="stylesheet" href="https://www.cnblogs.com/OnlyOnYourself-lzw/archive/2022/08/03/element-ui/lib/theme-chalk/index.css">
    
      <script>
      new Vue({
          el:"#app"
      })
          </script>
    
      </body>
    
      </html>
    
    

3、Element布局

  • Element提供了兩種布局方式,分別是
    • Layout布局
    • Container布局容器

3.1、Layout布局

  • 通過基礎的24分欄,迅速簡便地創建布局,也就是默認將一行分為24欄,根據頁面要求給每一列設定所占的欄數

    • 在左邊選單找到layout布局按鈕,然后找到自己喜歡的按鈕樣式,點擊顯示代碼,在下面就會展示出對應的代碼,顯示出的代碼中又樣式,有html標簽,將樣式拷貝到個人頁面的head標簽內,將html標簽拷貝到<div id="app"></div>標簽內
  • 整體頁面代碼如下

    • <!DOCTYPE html>
      <html lang="en">
      <head>
          <meta charset="UTF-8">
          <title>Title</title>
      
          <style>
              .el-row {
                  margin-bottom: 20px;
              }
              .el-col {
                  border-radius: 4px;
              }
              .bg-purple-dark {
                  background: #99a9bf;
              }
              .bg-purple {
                  background: #d3dce6;
              }
              .bg-purple-light {
                  background: #e5e9f2;
              }
              .grid-content {
                  border-radius: 4px;
                  min-height: 36px;
              }
              .row-bg {
                  padding: 10px 0;
                  background-color: #f9fafc;
              }
          </style>
      </head>
      <body>
      <div id="app">
          <el-row>
              <el-col :span="24"><div ></div></el-col>
          </el-row>
          <el-row>
              <el-col :span="12"><div ></div></el-col>
              <el-col :span="12"><div ></div></el-col>
          </el-row>
          <el-row>
              <el-col :span="8"><div ></div></el-col>
              <el-col :span="8"><div ></div></el-col>
              <el-col :span="8"><div ></div></el-col>
          </el-row>
          <el-row>
              <el-col :span="6"><div ></div></el-col>
              <el-col :span="6"><div ></div></el-col>
              <el-col :span="6"><div ></div></el-col>
              <el-col :span="6"><div ></div></el-col>
          </el-row>
          <el-row>
              <el-col :span="4"><div ></div></el-col>
              <el-col :span="4"><div ></div></el-col>
              <el-col :span="4"><div ></div></el-col>
              <el-col :span="4"><div ></div></el-col>
              <el-col :span="4"><div ></div></el-col>
              <el-col :span="4"><div ></div></el-col>
          </el-row>
      </div>
      <script src="https://www.cnblogs.com/OnlyOnYourself-lzw/archive/2022/08/03/js/vue.js"></script>
      <script src="https://www.cnblogs.com/OnlyOnYourself-lzw/archive/2022/08/03/element-ui/lib/index.js"></script>
      <link rel="stylesheet" href="https://www.cnblogs.com/OnlyOnYourself-lzw/archive/2022/08/03/element-ui/lib/theme-chalk/index.css">
      
      <script>
          new Vue({
              el:"#app"
          })
      </script>
      </body>
      </html>
      
  • 現在需要添加一行,要求該行顯示8個格子,通過計算每個各自占3欄,具體的html代碼如下所示

    • <!--
      添加一行,8個格子  24/8 = 3
      -->
      <el-row>
          <el-col :span="3"><div ></div></el-col>
          <el-col :span="3"><div ></div></el-col>
          <el-col :span="3"><div ></div></el-col>
          <el-col :span="3"><div ></div></el-col>
          <el-col :span="3"><div ></div></el-col>
          <el-col :span="3"><div ></div></el-col>
          <el-col :span="3"><div ></div></el-col>
          <el-col :span="3"><div ></div></el-col>
      </el-row>
      

3.2、Container布局容器

  • 概念

    • 用于布局的容器組件,方便快速搭建頁面的基本結構,如下圖就是布局容器效果
  • 如下圖是官網提供的Container布局容器實體

    • 該效果代碼中包含了樣式、頁面標簽、模型資料,將里面的樣式<style>拷貝到個人頁面的head標簽中;將html標簽拷貝到<div id="app"></div>標簽中,再將資料模型拷貝到vue物件的data()
  • 整體頁面代碼如下

    • <!DOCTYPE html>
      <html lang="en">
      <head>
          <meta charset="UTF-8">
          <title>Title</title>
      
          <style>
              .el-header {
                  background-color: #B3C0D1;
                  color: #333;
                  line-height: 60px;
              }
      
              .el-aside {
                  color: #333;
              }
          </style>
      </head>
      <body>
      <div id="app">
          <el-container style="height: 500px; border: 1px solid #eee">
              <el-aside  style="background-color: rgb(238, 241, 246)">
                  <el-menu :default-openeds="['1', '3']">
                      <el-submenu index="1">
                          <template slot="title"><i ></i>導航一</template>
                          <el-menu-item-group>
                              <template slot="title">分組一</template>
                              <el-menu-item index="1-1">選項1</el-menu-item>
                              <el-menu-item index="1-2">選項2</el-menu-item>
                          </el-menu-item-group>
                          <el-menu-item-group title="分組2">
                              <el-menu-item index="1-3">選項3</el-menu-item>
                          </el-menu-item-group>
                          <el-submenu index="1-4">
                              <template slot="title">選項4</template>
                              <el-menu-item index="1-4-1">選項4-1</el-menu-item>
                          </el-submenu>
                      </el-submenu>
                      <el-submenu index="2">
                          <template slot="title"><i ></i>導航二</template>
                          <el-submenu index="2-1">
                              <template slot="title">選項1</template>
                              <el-menu-item index="2-1-1">選項1-1</el-menu-item>
                          </el-submenu>
                      </el-submenu>
                      <el-submenu index="3">
                          <template slot="title"><i ></i>導航三</template>
                          <el-menu-item-group>
                              <template slot="title">分組一</template>
                              <el-menu-item index="3-1">選項1</el-menu-item>
                              <el-menu-item index="3-2">選項2</el-menu-item>
                          </el-menu-item-group>
                          <el-menu-item-group title="分組2">
                              <el-menu-item index="3-3">選項3</el-menu-item>
                          </el-menu-item-group>
                          <el-submenu index="3-4">
                              <template slot="title">選項4</template>
                              <el-menu-item index="3-4-1">選項4-1</el-menu-item>
                          </el-submenu>
                      </el-submenu>
                  </el-menu>
              </el-aside>
      
              <el-container>
                  <el-header style="text-align: right; font-size: 12px">
                      <el-dropdown>
                          <i  style="margin-right: 15px"></i>
                          <el-dropdown-menu slot="dropdown">
                              <el-dropdown-item>查看</el-dropdown-item>
                              <el-dropdown-item>新增</el-dropdown-item>
                              <el-dropdown-item>洗掉</el-dropdown-item>
                          </el-dropdown-menu>
                      </el-dropdown>
                      <span>王小虎</span>
                  </el-header>
      
                  <el-main>
                      <el-table :data="https://www.cnblogs.com/OnlyOnYourself-lzw/archive/2022/08/03/tableData">
                          <el-table-column prop="date" label="日期" >
                          </el-table-column>
                          <el-table-column prop="name" label="姓名" >
                          </el-table-column>
                          <el-table-column prop="address" label="地址">
                          </el-table-column>
                      </el-table>
                  </el-main>
              </el-container>
          </el-container>
      </div>
      <script src="https://www.cnblogs.com/OnlyOnYourself-lzw/archive/2022/08/03/js/vue.js"></script>
      <script src="https://www.cnblogs.com/OnlyOnYourself-lzw/archive/2022/08/03/element-ui/lib/index.js"></script>
      <link rel="stylesheet" href="https://www.cnblogs.com/OnlyOnYourself-lzw/archive/2022/08/03/element-ui/lib/theme-chalk/index.css">
      
      <script>
          new Vue({
              el:"#app",
              data() {
                  const item = {
                      date: '2016-05-02',
                      name: '王小虎',
                      address: '上海市普陀區金沙江路 1518 弄'
                  };
                  return {
                      tableData: Array(20).fill(item)
                  }
              }
          })
      </script>
      </body>
      </html>
      

4、綜合案例

  • 需求
    • 完成如下頁面效果
    • 要完成該頁面,需要先對這個頁面進行分析,看頁面由哪幾個部分組成,然后到官網進行拷貝并修改,頁面總共有如下組成部分
    • 還有一個是當點擊新增按鈕的時候,會在頁面正中間彈出一個對話框,如下所示

4.1、準備基本頁面

  • <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
    </head>
    <body>
    <div id="app">
    	
    </div>
    
    <script src="https://www.cnblogs.com/OnlyOnYourself-lzw/archive/2022/08/03/js/vue.js"></script>
    <script src="https://www.cnblogs.com/OnlyOnYourself-lzw/archive/2022/08/03/element-ui/lib/index.js"></script>
    <link rel="stylesheet" href="https://www.cnblogs.com/OnlyOnYourself-lzw/archive/2022/08/03/element-ui/lib/theme-chalk/index.css">
    
    <script>
        new Vue({
            el: "#app"
        })
    </script>
    </body>
    </html>
    

4.2、完成搜索表單展示

  • 在Element光網找到橫排的表單效果,然后拷貝代碼并進行修改
    • 點擊上面的顯示代碼后,就會展示出對應的代碼,下面是對這部分代碼進行分析的圖解
    • 分析結束后就可以根據需求效果修改代碼

4.3、完成批量洗掉和新增按鈕展示

  • 從Element官網找到具有著色效果的按鈕,并將代碼拷貝到我們自己的頁面上

4.4、完成對話框的展示

  • 在Element官網找到對話框的效果如下圖所示:
    • 對代碼進行分析的圖解如下圖所示
    • 上圖分析出來的模型資料需要在Vue物件中進行定義
  • 表單代碼如下所示

4.5、完成表格界面展示

  • 在左邊選單欄找到Table表格按鈕,找到需要的表格效果,并復制代碼,將html標簽拷貝到<div id="app"></div>中,如下所示
  • 將相關css樣式拷貝到head標簽中,如下所示
  • 將方法和模型資料拷貝到Vue物件指定的位置
  • 拷貝完成后通過瀏覽器打開可以看到表格的效果
  • 雖然表格效果出來了,但是顯示的表頭和資料并不是我們想要的,所以還需要對頁面代碼進行修改
    • 1.修改表頭和資料
      • 下面是對表格代碼進行分析的圖解,根據下圖書名修改自己的列數和列名
      • 修改完頁面后,還需要對系結的模型資料進行修改,下圖是對模型資料進行分析的圖解
    • 2.給表格添加操作列
      • 從官網上找到有按鈕的表格,復制過來進行修改
    • 3.給表格添加復選框和標號列
      • 預期效果如下
      • 此效果也是從Element官網進行拷貝,找到對應的表格效果,然后將其對應代碼拷貝至個人代碼中,如下是復選框列官網效果圖和代碼
      • 這里需要注意在<el-table>標簽上有一個事件@selection-change="handleSelectionChange",這里系結的函式也需要從官網拷貝到我們自己的頁面代碼中,函式代碼如下所示:
      • 從函式中又發現一個模型資料multipleSelection,所以還需要定義出該模型資料,標號列也用同樣的方式進行拷貝并修改
    • 4.給表格處理禁用和啟用

4.6、完成分頁條的展示

  • 在Element官網找到Pagination分頁,在頁面主體部分找到需要的效果,如下所示

    • 點擊顯示代碼,找到完整功能對應的代碼,接下來對該代碼進行分析

    • 上述代碼屬性說明

      • page-size:每頁顯示的條目數
      • page-sizes:每頁顯示個數選擇器的選項設定
      • :page-sizes="[100, 200, 300, 400]"對應的頁面效果如下:
      • currentPage:當前頁碼,我們點擊哪個頁面,此屬性值就是幾
      • total:總記錄數,用來設定總的資料目錄條數,該屬性設定后,Element會自動計算出需要分多少也給我們展示對應的代碼
    • 事件說明

      • size-change:pageSize改變的時候會觸發,也就是當我們改變了每頁顯示的條目數后,該事件會觸發

      • current-change:currentPage改變的時候會觸發,也就是當我們點擊了其他的頁碼后,該事件會復發

4.7、完整案例代碼

  • <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
        <!--elementui的css-->
        <link rel="stylesheet" href="https://www.cnblogs.com/OnlyOnYourself-lzw/archive/2022/08/03/element-ui/lib/theme-chalk/index.css">
        <!--先匯入vue的js-->
        <script src="https://www.cnblogs.com/OnlyOnYourself-lzw/archive/2022/08/03/js/vue.js"></script>
        <!--再匯入element的js-->
        <script src="https://www.cnblogs.com/OnlyOnYourself-lzw/archive/2022/08/03/element-ui/lib/index.js"></script>
    
        <style>
            .el-table .warning-row {
                background: oldlace;
            }
    
            .el-table .success-row {
                background: #f0f9eb;
            }
        </style>
    </head>
    <body>
        <div id="app">
            <!--搜索表單-->
            <el-form :inline="true" :model="brand" >
                <el-form-item label="當前狀態">
                    <el-select v-model="brand.status" placeholder="當前狀態">
                        <el-option label="啟用" value="https://www.cnblogs.com/OnlyOnYourself-lzw/archive/2022/08/03/1"></el-option>
                        <el-option label="禁用" value="https://www.cnblogs.com/OnlyOnYourself-lzw/archive/2022/08/03/0"></el-option>
                    </el-select>
                </el-form-item>
                <el-form-item label="企業名稱">
                    <el-input v-model="brand.companyName" placeholder="企業名稱"></el-input>
                </el-form-item>
                <el-form-item label="品牌名稱">
                    <el-input v-model="brand.brandName" placeholder="品牌名稱"></el-input>
                </el-form-item>
                <el-form-item>
                    <el-button type="primary" @click="onSubmit">查詢</el-button>
                </el-form-item>
            </el-form>
    
            <!--倆按鈕-->
            <el-row>
                <el-button type="danger" plain>批量洗掉</el-button>
                <el-button type="primary" plain @click="dialogFormVisible = true">新增</el-button>
            </el-row>
    
            <!--添加表單的對話框-->
            <el-dialog title="編輯品牌" :visible.sync="dialogFormVisible" >
                <el-form ref="form" :model="brand" label->
                    <el-form-item label="品牌名稱">
                        <el-input v-model="brand.brandName"></el-input>
                    </el-form-item>
                    <el-form-item label="企業名稱">
                        <el-input v-model="brand.companyName"></el-input>
                    </el-form-item>
                    <el-form-item label="排序">
                        <el-input v-model="brand.ordered"></el-input>
                    </el-form-item>
                    <el-form-item label="備注">
                        <el-input type="textarea" v-model="brand.desc"></el-input>
                    </el-form-item>
                    <el-form-item label="狀態">
                        <el-switch v-model="brand.status" active-value="https://www.cnblogs.com/OnlyOnYourself-lzw/archive/2022/08/03/1" inactive-value="https://www.cnblogs.com/OnlyOnYourself-lzw/archive/2022/08/03/0"></el-switch>
                    </el-form-item>
                    <el-form-item>
                        <el-button type="primary" @click="saveBrand">提交</el-button>
                        <el-button @click="dialogFormVisible = false">取消</el-button>
                    </el-form-item>
                </el-form>
            </el-dialog>
    
            <!--
            表格
                @selection-change:多選框發生選擇變化的時候觸發的事件
    
            -->
            <el-table
                    :data="https://www.cnblogs.com/OnlyOnYourself-lzw/archive/2022/08/03/tableData"
                    style="width: 100%"
                    :row-class-name="tableRowClassName"
                    @selection-change="handleSelectionChange">
                <el-table-column
                        type="selection"
                        >
                </el-table-column>
                <el-table-column
                        type="index"
                        >
                </el-table-column>
                <el-table-column
                        prop="brandName"
                        label="品牌名稱"
                        align="center">
                </el-table-column>
                <el-table-column
                        prop="companyName"
                        label="企業名稱"
                        align="center">
                </el-table-column>
                <el-table-column
                        prop="ordered"
                        label="排序"
                        align="center">
                </el-table-column>
                <el-table-column
                        prop="status"
                        label="當前狀態"
                        align="center">
                    <!--獲取到status值,然后進行判斷-->
                    <template slot-scope="scope">
                        <el-tag>{{scope.row.status=='1'?'啟用':'禁用'}}</el-tag>
                    </template>
                </el-table-column>
                <el-table-column
                        label="操作"
                        align="center">
                    <template slot-scope="scope">
                        <el-button type="primary" @click="handleEdit(scope.$index, scope.row)">編輯</el-button>
                        <el-button type="danger" @click="handleDelete(scope.$index, scope.row)">洗掉</el-button>
                    </template>
                </el-table-column>
            </el-table>
    
            <!--
             分頁條:
                 @size-change:每頁條數變化的時候
                 @current-change:頁碼變化的時候
                 :current-page:展示的頁碼
                 :page-sizes:每頁顯示的條數可選串列
                 :page-size:每頁顯示的條數
                 :total:總條數
            -->
            <el-pagination
                    @size-change="handleSizeChange"
                    @current-change="handleCurrentChange"
                    :current-page="currentPage"
                    :page-sizes="[5, 10, 15, 20]"
                    :page-size="10"
                    layout="total, sizes, prev, pager, next, jumper"
                    :total="400">
            </el-pagination>
        </div>
    </body>
    <script>
        new Vue({
            el:"#app",
            data() {
                return {
                    brand: {
                        status: '',
                        companyName: '',
                        brandName: ''
                    },
                    dialogFormVisible: false,
                    tableData: [{
                        brandName: '紅米',
                        companyName: '小米科技',
                        ordered: '1',
                        status:'0'
                    },{
                        brandName: '紅米',
                        companyName: '小米科技',
                        ordered: '1',
                        status:'1'
                    },{
                        brandName: '紅米',
                        companyName: '小米科技',
                        ordered: '1',
                        status:'0'
                    },{
                        brandName: '紅米',
                        companyName: '小米科技',
                        ordered: '1',
                        status:'1'
                    },{
                        brandName: '紅米',
                        companyName: '小米科技',
                        ordered: '1',
                        status:'0'
                    },{
                        brandName: '紅米',
                        companyName: '小米科技',
                        ordered: '1',
                        status:'0'
                    }],
                    currentPage: 2
                }
            },
            methods: {
                onSubmit() {
                    console.log(this.brand);
                },
                saveBrand() {
                    console.log(this.brand);
                },
                //切換表格行的樣式
                tableRowClassName({row, rowIndex}) {
                    if (rowIndex%2 === 0) {
                        return 'success-row';
                    }
                    return '';
                },
    
                //處理選擇框變化的事件方法
                handleSelectionChange(val) {
                    console.log(val);
                    this.multipleSelection = val;
                },
                //處理編輯操作
                handleEdit(index, row) {
                    console.log(index, row);
                },
    
                //處理洗掉操作
                handleDelete(index, row) {
                    console.log(index, row);
                },
    
                //獲取每條顯示的條數
                handleSizeChange(val) {
                    console.log(`每頁 ${val} 條`);
                },
    
                //獲取當前頁碼
                handleCurrentChange(val) {
                    console.log(`當前頁: ${val}`);
                }
            }
        });
    </script>
    </html>
    

轉載請註明出處,本文鏈接:https://www.uj5u.com/qiye/500842.html

標籤:其他

上一篇:10-Ajax&Vue

下一篇:day 07 物件及其定時器與日期

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • IEEE1588PTP在數字化變電站時鐘同步方面的應用

    IEEE1588ptp在數字化變電站時鐘同步方面的應用 京準電子科技官微——ahjzsz 一、電力系統時間同步基本概況 隨著對IEC 61850標準研究的不斷深入,國內外學者提出基于IEC61850通信標準體系建設數字化變電站的發展思路。數字化變電站與常規變電站的顯著區別在于程序層傳統的電流/電壓互 ......

    uj5u.com 2020-09-10 03:51:52 more
  • HTTP request smuggling CL.TE

    CL.TE 簡介 前端通過Content-Length處理請求,通過反向代理或者負載均衡將請求轉發到后端,后端Transfer-Encoding優先級較高,以TE處理請求造成安全問題。 檢測 發送如下資料包 POST / HTTP/1.1 Host: ac391f7e1e9af821806e890 ......

    uj5u.com 2020-09-10 03:52:11 more
  • 網路滲透資料大全單——漏洞庫篇

    網路滲透資料大全單——漏洞庫篇漏洞庫 NVD ——美國國家漏洞庫 →http://nvd.nist.gov/。 CERT ——美國國家應急回應中心 →https://www.us-cert.gov/ OSVDB ——開源漏洞庫 →http://osvdb.org Bugtraq ——賽門鐵克 →ht ......

    uj5u.com 2020-09-10 03:52:15 more
  • 京準講述NTP時鐘服務器應用及原理

    京準講述NTP時鐘服務器應用及原理京準講述NTP時鐘服務器應用及原理 安徽京準電子科技官微——ahjzsz 北斗授時原理 授時是指接識訓通過某種方式獲得本地時間與北斗標準時間的鐘差,然后調整本地時鐘使時差控制在一定的精度范圍內。 衛星導航系統通常由三部分組成:導航授時衛星、地面檢測校正維護系統和用戶 ......

    uj5u.com 2020-09-10 03:52:25 more
  • 利用北斗衛星系統設計NTP網路時間服務器

    利用北斗衛星系統設計NTP網路時間服務器 利用北斗衛星系統設計NTP網路時間服務器 安徽京準電子科技官微——ahjzsz 概述 NTP網路時間服務器是一款支持NTP和SNTP網路時間同步協議,高精度、大容量、高品質的高科技時鐘產品。 NTP網路時間服務器設備采用冗余架構設計,高精度時鐘直接來源于北斗 ......

    uj5u.com 2020-09-10 03:52:35 more
  • 詳細解讀電力系統各種對時方式

    詳細解讀電力系統各種對時方式 詳細解讀電力系統各種對時方式 安徽京準電子科技官微——ahjzsz,更多資料請添加VX 衛星同步時鐘是我京準公司開發研制的應用衛星授時時技術的標準時間顯示和發送的裝置,該裝置以M國全球定位系統(GLOBAL POSITIONING SYSTEM,縮寫為GPS)或者我國北 ......

    uj5u.com 2020-09-10 03:52:45 more
  • 如何保證外包團隊接入企業內網安全

    不管企業規模的大小,只要企業想省錢,那么企業的某些服務就一定會采用外包的形式,然而看似美好又經濟的策略,其實也有不好的一面。下面我通過安全的角度來聊聊使用外包團的安全隱患問題。 先看看什么服務會使用外包的,最常見的就是話務/客服這種需要大量重復性、無技術性的服務,或者是一些銷售外包、特殊的職能外包等 ......

    uj5u.com 2020-09-10 03:52:57 more
  • PHP漏洞之【整型數字型SQL注入】

    0x01 什么是SQL注入 SQL是一種注入攻擊,通過前端帶入后端資料庫進行惡意的SQL陳述句查詢。 0x02 SQL整型注入原理 SQL注入一般發生在動態網站URL地址里,當然也會發生在其它地發,如登錄框等等也會存在注入,只要是和資料庫打交道的地方都有可能存在。 如這里http://192.168. ......

    uj5u.com 2020-09-10 03:55:40 more
  • [GXYCTF2019]禁止套娃

    git泄露獲取原始碼 使用GET傳參,引數為exp 經過三層過濾執行 第一層過濾偽協議,第二層過濾帶引數的函式,第三層過濾一些函式 preg_replace('/[a-z,_]+\((?R)?\)/', NULL, $_GET['exp'] (?R)參考當前正則運算式,相當于匹配函式里的引數 因此傳遞 ......

    uj5u.com 2020-09-10 03:56:07 more
  • 等保2.0實施流程

    流程 結論 ......

    uj5u.com 2020-09-10 03:56:16 more
最新发布
  • 使用Django Rest framework搭建Blog

    在前面的Blog例子中我們使用的是GraphQL, 雖然GraphQL的使用處于上升趨勢,但是Rest API還是使用的更廣泛一些. 所以還是決定回到傳統的rest api framework上來, Django rest framework的官網上給了一個很好用的QuickStart, 我參考Qu ......

    uj5u.com 2023-04-20 08:17:54 more
  • 記錄-new Date() 我忍你很久了!

    這里給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 大家平時在開發的時候有沒被new Date()折磨過?就是它的諸多怪異的設定讓你每每用的時候,都可能不小心踩坑。造成程式意外出錯,卻一下子找不到問題出處,那叫一個煩透了…… 下面,我就列舉它的“四宗罪”及應用思考 可惡的四宗罪 1. Sa ......

    uj5u.com 2023-04-20 08:17:47 more
  • 使用Vue.js實作文字跑馬燈效果

    實作文字跑馬燈效果,首先用到 substring()截取 和 setInterval計時器 clearInterval()清除計時器 效果如下: 實作代碼如下: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta ......

    uj5u.com 2023-04-20 08:12:31 more
  • JavaScript 運算子

    JavaScript 運算子/運算子 在 JavaScript 中,有一些運算子可以使代碼更簡潔、易讀和高效。以下是一些常見的運算子: 1、可選鏈運算子(optional chaining operator) ?.是可選鏈運算子(optional chaining operator)。?. 可選鏈操 ......

    uj5u.com 2023-04-20 08:02:25 more
  • CSS—相對單位rem

    一、概述 rem是一個相對長度單位,它的單位長度取決于根標簽html的字體尺寸。rem即root em的意思,中文翻譯為根em。瀏覽器的文本尺寸一般默認為16px,即默認情況下: 1rem = 16px rem布局原理:根據CSS媒體查詢功能,更改根標簽的字體尺寸,實作rem單位隨螢屏尺寸的變化,如 ......

    uj5u.com 2023-04-20 08:02:21 more
  • 我的第一個NPM包:panghu-planebattle-esm(胖虎飛機大戰)使用說明

    好家伙,我的包終于開發完啦 歡迎使用胖虎的飛機大戰包!! 為你的主頁添加色彩 這是一個有趣的網頁小游戲包,使用canvas和js開發 使用ES6模塊化開發 效果圖如下: (覺得圖片太sb的可以自己改) 代碼已開源!! Git: https://gitee.com/tang-and-han-dynas ......

    uj5u.com 2023-04-20 08:01:50 more
  • 如何在 vue3 中使用 jsx/tsx?

    我們都知道,通常情況下我們使用 vue 大多都是用的 SFC(Signle File Component)單檔案組件模式,即一個組件就是一個檔案,但其實 Vue 也是支持使用 JSX 來撰寫組件的。這里不討論 SFC 和 JSX 的好壞,這個仁者見仁智者見智。本篇文章旨在帶領大家快速了解和使用 Vu ......

    uj5u.com 2023-04-20 08:01:37 more
  • 【Vue2.x原始碼系列06】計算屬性computed原理

    本章目標:計算屬性是如何實作的?計算屬性快取原理以及洋蔥模型的應用?在初始化Vue實體時,我們會給每個計算屬性都創建一個對應watcher,我們稱之為計算屬性watcher ......

    uj5u.com 2023-04-20 08:01:31 more
  • http1.1與http2.0

    一、http是什么 通俗來講,http就是計算機通過網路進行通信的規則,是一個基于請求與回應,無狀態的,應用層協議。常用于TCP/IP協議傳輸資料。目前任何終端之間任何一種通信方式都必須按Http協議進行,否則無法連接。tcp(三次握手,四次揮手)。 請求與回應:客戶端請求、服務端回應資料。 無狀態 ......

    uj5u.com 2023-04-20 08:01:10 more
  • http1.1與http2.0

    一、http是什么 通俗來講,http就是計算機通過網路進行通信的規則,是一個基于請求與回應,無狀態的,應用層協議。常用于TCP/IP協議傳輸資料。目前任何終端之間任何一種通信方式都必須按Http協議進行,否則無法連接。tcp(三次握手,四次揮手)。 請求與回應:客戶端請求、服務端回應資料。 無狀態 ......

    uj5u.com 2023-04-20 08:00:32 more