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 中文字幕不卡视频,亚洲精品网站在线观看不卡无广告,99视频久久

          整合營銷服務商

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

          免費咨詢熱線:

          ElementUI:文本框實現遠程搜索的用法

          ElementUI:文本框實現遠程搜索的用法

          天繼續給大家分享一下Element UI 多選框組用法筆記,直接上代碼!

          1、HTML

          <el-form-item label="用戶列表">
              <el-autocomplete
                      class="inline-input"
                      @clear="clearUser"
                      clearable
                      v-model="paramData.userName"
                      :fetch-suggestions="querySearch"
                      placeholder="請輸入用戶名"
                      @select="handleSelect"
              >
              </el-autocomplete>
          </el-form-item>

          2、JS


          var vue=new Vue({
              data: {
                  paramData: {
                      userId: "",
                      userName: ""
                  },
                  userList: []
              },
              created: function() {
                  var self=this;
                  self.initUser("");
              },
              mounted: function() {},
              methods: {},
              methods: {
                  initUser: function(userName) {
                      var self=this;
                      var queryParam={};
                      $.ajax({
                          url: xxx,
                          contentType: 'application/json',
                          data: JSON.stringify(queryParam),
                          success: function(resultData) {
                              if (resultData.success) {
                                  self.userList=result.data;
                              } else {
                                  self.userList=[];
                              }
                          }
                      });
                  },
                  handleSelect: function(item) {
                      var self=this;
                      self.paramData.userName=item.value;
                      self.paramData.userId=item.id;
                      self.onSearch();
                  },
                  querySearch: function(queryString, cb) {
                      var self=this;
                      var queryParam={};
                      $.ajax({
                          url: xxx,
                          contentType: 'application/json',
                          data: JSON.stringify(queryParam),
                          success: function(resultData) {
                              if (resultData.success) {
                                  cb(result.data);
                              } else {
                                  cb([]);
                              }
                          }
                      });
                  },
                  clearUser: function() {
                      var self=this;
                      self.paramData.userName="";
                      self.paramData.userId="";
                      //重新加載數據列表
                  }
              }
          });
          
          

          以上是分享內容,感謝閱讀,歡迎收藏、點贊、轉發。您的支持是我最大的創作動力,有問題可以留言大家共同進步!

           在開始之前,我們先來想一個問題,用戶為什么要使用搜索功能呢? 今天我帶大家一起來探討一下UI搜索頁面的一些設計方法。

            用戶搜索的目的是為了快速找到自己想要的結果!搜索頁是用戶進行搜索的第一站,最理想的狀態就是用戶不需要輸入文字或者語音等交互操作就可以點擊查看搜索結果,所以搜索頁中推薦內容對提高用戶搜索效率有著非常重要的作用。

            一個完整的搜索過程大體分為三部分:尋找搜索入口、進入頁面搜索、查看搜索結果。接下來將從這3點來講述:

            一、搜索入口

            搜索入口樣式常見的可分為2種:1搜索框、2搜索icon

            搜索框類根據位置分類常見的有三種:

            1.位于頁面頂部(導航欄中間或下方) ,比較常見的樣式。


            2.位于頁面中間,搜索功能作為核心部分展示。


            3.位于頁面底部作為獨立的Tab存在。常見與發現頁面或應用商店等內容類APP中。


            2搜索icon 樣式:

            一般位于頁面導航欄左右兩邊,可與其他icon并類存在。


            二、搜索頁面

            搜索頁面一般由三部分組成:1頂部搜索區 2中間輔助區 3底部鍵盤,有些產品也支持實時搜索,我們一一來看:

            2.1頂部搜索區

            頂部搜索區:包括輸入框,有些也會伴隨拍照、語音等輔助功能。


            2.2中間輔助區

            中間輔助區:主要包括“歷史搜索”和“熱門推薦”兩部分內容。常見樣式有以下幾種:

            1標簽式:

            在設計形式上一般采用“文字”+“背景”形式,標簽文字在 @2x 圖下一般是 24px 大小,標簽背景一般以淺灰色的圓角矩形為主。

            優點:提取用戶最關注的核心關鍵詞,相比其他形式區域內展示標簽數量多,展示效率高。

            缺點:展示信息密集且樣式單一,缺乏感染力。

            適合場景:需要高效展示搜索內容的信息頁面。


            2.列表式:

            在設計樣式一般由多個橫向列表單元組成,列表單元內主要分為“純文字”和“圖標+文字”兩種設計形式

            優點:可借助縱軸交互無限下拉展示,通常以短句的形式展示核心內容,展示信息更全面,根據產品類型的不同還會伴有圖標、輔助文案等信息展示;列表流的設計符合用戶自上到下、自左到右的閱讀習慣。

            缺點:一屏之內顯示的內容遠少于標簽式能展示的內容,展示效率低;在伴隨圖標、輔助文案的情況下,用戶的閱讀視線需要進行多次跳轉,閱讀成本高。

            適合場景:需要全面展示推薦信息的頁面。


            3.Tab欄式:

            由頂部 Tab 選項和推薦列表組成,兩者有強烈的依附關系。在設計細節上通常會添加排名、標簽、圖標等作為輔助性信息,增強用戶點擊欲望。

            優點:通過Tab 欄可以展示多維度的推薦內容,展示信息維度廣,間接地提高了信息展示效率。

            缺點:交互成本高,需要用戶先點擊 Tab 欄再選擇具體的推薦關鍵詞;操作門檻高,對于幼兒、老年等非主流用戶群體學習成本高。

            適合場景:需要全面多維度展示的頁面。


            4.圖片式:

            在設計上主要以圖片和標題文字組成,UI設計中搜索頁設計指南https://www.aaa-cg.com.cn/ui/2609.html?gpf在設計細節上會添加標簽、圖標、推薦文案等輔助性信息。

            優點:圖片相比于文字更加能吸引用戶的注意力,視覺沖擊力強,識別成本低;通常圖片中會包含標簽、圖標、說明文案等輔助信息,展示信息全面。

            缺點:圖片面積占比大,信息展示效率低;需要找到和標題釋義一致的圖片要耗費較高的人力成本,后期維護成本高。

            適合場景:需要增強頁面感染力,激發用戶點擊欲望的頁面。


            5.條件篩選:

            設計上主要以文字為主,部分產品也會添加圖標輔助用戶快速識別。

            優點:限定搜索維度,更加精準。

            缺點:交互成本高,想要精準搜索必須先點擊篩選條件。

            適合場景:需要精準化搜索的頁面。


            6.組合樣式:

            不同形式的推薦搜索內容在設計上都有各自的優缺點,選擇某一種形式取決于頁面當前承擔核心業務是什么,我們在實際設計當中可以有選擇的進行多種形式的組合(最好不要超過兩種),進行取長補短。

            適合場景:最大化的發揮搜索推薦的優勢。


            2.3底部鍵盤

            底部的鍵盤通常也會伴隨著輔助功能,例如語音、掃一掃等功能,例如淘寶的鍵盤頂部功能。


            2.4實時搜索

            用戶在輸入關鍵詞時,下方頁面會實時更新內容,一種是實時呈現搜索結果,一種是呈現聯想詞列表。


            三、搜索結果

            搜索結果通常分為常規列表、帶有篩選排序功能的結果列表以及搜索為空的頁面。

            1.常規列表

            簡易結果列表,有些也帶有分類標簽和關鍵詞高亮顯示。


            2.篩選排序

            可進一步對結果做篩選或排序,如電商、旅游等類型產品較多使用此功能。


            3.結果為空

            當無搜索結果時,可用展位圖+提示語來告知用戶,也可在此頁面上推薦其他內容,給用戶多一點選擇。


            希望這篇文章能幫助大家在拿到設計需求沒有什么想法的時候,可以快速產出一套搜索頁設計方案 。而其中的細節確定需要大家結合自身產品特點,選擇適合自己的部分。因此,您現在已經了解了與UI設計師的工作相關的主要技能。如果您想了解更多信息,請給我點個關注,我之后還會發包含有關在該領域工作的更多相關文章。

          UI設計中首頁設計指南

          UI設計中按鈕設計攻略

          UI設計中Tab設計指南

          Ui設計中LOGO設計指南

          如何運用情緒版進行設計

          、前言

          這個IP地址輸入框控件,估計寫爛了,網上隨便一搜索,保證一大堆,估計也是因為這個控件太容易了,非常適合新手練手,一般的思路都是用4個qlineedit控件拼起來,然后每個輸入框設置正則表達式過濾只能輸入3位數字,然后安裝事件過濾器識別回車自動跳到下一個輸入框。關于如何設置正則表達式過濾,這個可以搜索查到,本人也不大懂這個規則,貌似還有專門的書籍專門介紹正則表達式,可能這塊非常強大。

          開源地址:https://gitee.com/feiyangqingyun/QWidgetDemo https://github.com/feiyangqingyun/QWidgetDemo

          二、實現的功能

          • 1:可設置IP地址,自動填入框
          • 2:可清空IP地址
          • 3:支持按下小圓點自動切換
          • 4:支持退格鍵自動切換
          • 5:支持IP地址過濾
          • 6:可設置背景色/邊框顏色/邊框圓角角度

          三、效果圖

          四、頭文件代碼

          #ifndef IPADDRESS_H
          #define IPADDRESS_H
          
          /**
           * IP地址輸入框控件 作者:feiyangqingyun(QQ:517216493) 2017-8-11
           * 1:可設置IP地址,自動填入框
           * 2:可清空IP地址
           * 3:支持按下小圓點自動切換
           * 4:支持退格鍵自動切換
           * 5:支持IP地址過濾
           * 6:可設置背景色/邊框顏色/邊框圓角角度
           */
          
          #include <QWidget>
          
          class QLabel;
          class QLineEdit;
          
          #ifdef quc
          #if (QT_VERSION < QT_VERSION_CHECK(5,7,0))
          #include <QtDesigner/QDesignerExportWidget>
          #else
          #include <QtUiPlugin/QDesignerExportWidget>
          #endif
          
          class QDESIGNER_WIDGET_EXPORT IPAddress : public QWidget
          #else
          class IPAddress : public QWidget
          #endif
          
          {
              Q_OBJECT
              Q_PROPERTY(QString ip READ getIP WRITE setIP)
          
          public:
              explicit IPAddress(QWidget *parent=0);
          
          protected:
              bool eventFilter(QObject *watched, QEvent *event);
          
          private:
              QLabel *labDot1;    //第一個小圓點
              QLabel *labDot2;    //第二個小圓點
              QLabel *labDot3;    //第三個小圓點
          
              QLineEdit *txtIP1;  //IP地址網段輸入框1
              QLineEdit *txtIP2;  //IP地址網段輸入框2
              QLineEdit *txtIP3;  //IP地址網段輸入框3
              QLineEdit *txtIP4;  //IP地址網段輸入框4
          
              QString ip;         //IP地址
              QString bgColor;    //背景顏色
              QString borderColor;//邊框顏色
              int borderRadius;   //邊框圓角角度
          
          private slots:
              void textChanged(const QString &text);
          
          public:
              //獲取IP地址
              QString getIP()                 const;
          
              QSize sizeHint()                const;
              QSize minimumSizeHint()         const;
          
          public Q_SLOTS:
              //設置IP地址
              void setIP(const QString &ip);
              //清空
              void clear();
          
              //設置背景顏色
              void setBgColor(const QString &bgColor);
              //設置邊框顏色
              void setBorderColor(const QString &borderColor);
              //設置邊框圓角角度
              void setBorderRadius(int borderRadius);
          
          };
          
          #endif // IPADDRESS_H
          
          
          

          【領QT開發教程學習資料,點擊下方鏈接莬費領取↓↓,先碼住不迷路~】

          點擊這里:Qt資料領取(視頻教程+文檔+代碼+項目實戰)

          五、核心代碼

          #pragma execution_character_set("utf-8")
          
          #include "ipaddress.h"
          #include "qlabel.h"
          #include "qlineedit.h"
          #include "qboxlayout.h"
          #include "qregexp.h"
          #include "qvalidator.h"
          #include "qevent.h"
          #include "qdebug.h"
          
          IPAddress::IPAddress(QWidget *parent) : QWidget(parent)
          {
              bgColor="#FFFFFF";
              borderColor="#A6B5B8";
              borderRadius=3;
          
              //用于顯示小圓點的標簽,居中對齊
              labDot1=new QLabel;
              labDot1->setAlignment(Qt::AlignCenter);
              labDot1->setText(".");
          
              labDot2=new QLabel;
              labDot2->setAlignment(Qt::AlignCenter);
              labDot2->setText(".");
          
              labDot3=new QLabel;
              labDot3->setAlignment(Qt::AlignCenter);
              labDot3->setText(".");
          
              //用于輸入IP地址的文本框,居中對齊
              txtIP1=new QLineEdit;
              txtIP1->setObjectName("txtIP1");
              txtIP1->setAlignment(Qt::AlignCenter);
              txtIP1->setSizePolicy(QSizePolicy::Expanding, QSizePolicy::Expanding);
              connect(txtIP1, SIGNAL(textChanged(QString)), this, SLOT(textChanged(QString)));
          
              txtIP2=new QLineEdit;
              txtIP2->setObjectName("txtIP2");
              txtIP2->setAlignment(Qt::AlignCenter);
              txtIP2->setSizePolicy(QSizePolicy::Expanding, QSizePolicy::Expanding);
              connect(txtIP2, SIGNAL(textChanged(QString)), this, SLOT(textChanged(QString)));
          
              txtIP3=new QLineEdit;
              txtIP3->setObjectName("txtIP3");
              txtIP3->setAlignment(Qt::AlignCenter);
              txtIP3->setSizePolicy(QSizePolicy::Expanding, QSizePolicy::Expanding);
              connect(txtIP3, SIGNAL(textChanged(QString)), this, SLOT(textChanged(QString)));
          
              txtIP4=new QLineEdit;
              txtIP4->setObjectName("txtIP4");
              txtIP4->setAlignment(Qt::AlignCenter);
              txtIP4->setSizePolicy(QSizePolicy::Expanding, QSizePolicy::Expanding);
              connect(txtIP4, SIGNAL(textChanged(QString)), this, SLOT(textChanged(QString)));
          
              //設置IP地址校驗過濾
              QRegExp regExp("(2[0-5]{2}|2[0-4][0-9]|1?[0-9]{1,2})");
              QRegExpValidator *validator=new QRegExpValidator(regExp, this);
              txtIP1->setValidator(validator);
              txtIP2->setValidator(validator);
              txtIP3->setValidator(validator);
              txtIP4->setValidator(validator);
          
              //綁定事件過濾器,識別鍵盤按下
              txtIP1->installEventFilter(this);
              txtIP2->installEventFilter(this);
              txtIP3->installEventFilter(this);
              txtIP4->installEventFilter(this);
          
              QFrame *frame=new QFrame;
              frame->setObjectName("frameIP");
          
              QStringList qss;
              qss.append(QString("QFrame#frameIP{border:1px solid %1;border-radius:%2px;}").arg(borderColor).arg(borderRadius));
              qss.append(QString("QLabel{min-width:15px;background-color:%1;}").arg(bgColor));
              qss.append(QString("QLineEdit{background-color:%1;border:none;}").arg(bgColor));
              qss.append(QString("QLineEdit#txtIP1{border-top-left-radius:%1px;border-bottom-left-radius:%1px;}").arg(borderRadius));
              qss.append(QString("QLineEdit#txtIP4{border-top-right-radius:%1px;border-bottom-right-radius:%1px;}").arg(borderRadius));
              frame->setStyleSheet(qss.join(""));
          
              QVBoxLayout *verticalLayout=new QVBoxLayout(this);
              verticalLayout->setMargin(0);
              verticalLayout->setSpacing(0);
              verticalLayout->addWidget(frame);
          
              //將控件按照橫向布局排列
              QHBoxLayout *layout=new QHBoxLayout(frame);
              layout->setMargin(0);
              layout->setSpacing(0);
              layout->addWidget(txtIP1);
              layout->addWidget(labDot1);
              layout->addWidget(txtIP2);
              layout->addWidget(labDot2);
              layout->addWidget(txtIP3);
              layout->addWidget(labDot3);
              layout->addWidget(txtIP4);
          }
          
          bool IPAddress::eventFilter(QObject *watched, QEvent *event)
          {
              if (event->type()==QEvent::KeyPress) {
                  QLineEdit *txt=(QLineEdit *)watched;
                  if (txt==txtIP1 || txt==txtIP2 || txt==txtIP3 || txt==txtIP4) {
                      QKeyEvent *key=(QKeyEvent *)event;
          
                      //如果當前按下了小數點則移動焦點到下一個輸入框
                      if (key->text()==".") {
                          this->focusNextChild();
                      }
          
                      //如果按下了退格鍵并且當前文本框已經沒有了內容則焦點往前移
                      if (key->key()==Qt::Key_Backspace) {
                          if (txt->text().length() <=1) {
                              this->focusNextPrevChild(false);
                          }
                      }
                  }
              }
          
              return QWidget::eventFilter(watched, event);
          }
          
          void IPAddress::textChanged(const QString &text)
          {
              int len=text.length();
              int value=text.toInt();
          
              //判斷當前是否輸入完成一個網段,是的話則自動移動到下一個輸入框
              if (len==3) {
                  if (value >=100 && value <=255) {
                      this->focusNextChild();
                  }
              }
          
              //拼接成完整IP地址
              ip=QString("%1.%2.%3.%4").arg(txtIP1->text()).arg(txtIP2->text()).arg(txtIP3->text()).arg(txtIP4->text());
          }
          
          QString IPAddress::getIP() const
          {
              return this->ip;
          }
          
          QSize IPAddress::sizeHint() const
          {
              return QSize(250, 20);
          }
          
          QSize IPAddress::minimumSizeHint() const
          {
              return QSize(30, 10);
          }
          
          void IPAddress::setIP(const QString &ip)
          {
              //先檢測IP地址是否合法
              QRegExp regExp("((2[0-4]\\d|25[0-5]|[01]?\\d\\d?)\\.){3}(2[0-4]\\d|25[0-5]|[01]?\\d\\d?)");
              if (!regExp.exactMatch(ip)) {
                  return;
              }
          
              if (this->ip !=ip) {
                  this->ip=ip;
          
                  //將IP地址填入各個網段
                  QStringList list=ip.split(".");
                  txtIP1->setText(list.at(0));
                  txtIP2->setText(list.at(1));
                  txtIP3->setText(list.at(2));
                  txtIP4->setText(list.at(3));
              }
          }
          
          void IPAddress::clear()
          {
              txtIP1->clear();
              txtIP2->clear();
              txtIP3->clear();
              txtIP4->clear();
              txtIP1->setFocus();
          }
          
          void IPAddress::setBgColor(const QString &bgColor)
          {
              if (this->bgColor !=bgColor) {
                  this->bgColor=bgColor;
              }
          }
          
          void IPAddress::setBorderColor(const QString &borderColor)
          {
              if (this->borderColor !=borderColor) {
                  this->borderColor=borderColor;
              }
          }
          
          void IPAddress::setBorderRadius(int borderRadius)
          {
              if (this->borderRadius !=borderRadius) {
                  this->borderRadius=borderRadius;
              }
          }
          
          
          

          六、控件介紹

          1. 超過160個精美控件,涵蓋了各種儀表盤、進度條、進度球、指南針、曲線圖、標尺、溫度計、導航條、導航欄,flatui、高亮按鈕、滑動選擇器、農歷等。遠超qwt集成的控件數量。
          2. 每個類都可以獨立成一個單獨的控件,零耦合,每個控件一個頭文件和一個實現文件,不依賴其他文件,方便單個控件以源碼形式集成到項目中,較少代碼量。qwt的控件類環環相扣,高度耦合,想要使用其中一個控件,必須包含所有的代碼。
          3. 全部純Qt編寫,QWidget+QPainter繪制,支持Qt4.6到Qt5.13的任何Qt版本,支持mingw、msvc、gcc等編譯器,支持任意操作系統比如windows+linux+mac+嵌入式linux等,不亂碼,可直接集成到Qt Creator中,和自帶的控件一樣使用,大部分效果只要設置幾個屬性即可,極為方便。
          4. 每個控件都有一個對應的單獨的包含該控件源碼的DEMO,方便參考使用。同時還提供一個所有控件使用的集成的DEMO。
          5. 每個控件的源代碼都有詳細中文注釋,都按照統一設計規范編寫,方便學習自定義控件的編寫。
          6. 每個控件默認配色和demo對應的配色都非常精美。
          7. 超過130個可見控件,6個不可見控件。
          8. 部分控件提供多種樣式風格選擇,多種指示器樣式選擇。
          9. 所有控件自適應窗體拉伸變化。
          10. 集成自定義控件屬性設計器,支持拖曳設計,所見即所得,支持導入導出xml格式。
          11. 自帶activex控件demo,所有控件可以直接運行在ie瀏覽器中。
          12. 集成fontawesome圖形字體+阿里巴巴iconfont收藏的幾百個圖形字體,享受圖形字體帶來的樂趣。
          13. 所有控件最后生成一個動態庫文件(dll或者so等),可以直接集成到qtcreator中拖曳設計使用。
          14. 目前已經有qml版本,后期會考慮出pyqt版本,如果用戶需求量很大的話。
          15. 自定義控件插件開放動態庫使用(永久免費),無任何后門和限制,請放心使用。
          16. 目前已提供32個版本的dll,其中qt_5_7_0_mingw530_32這個版本會一直保證最新的完整的。
          17. 不定期增加控件和完善控件,不定期更新SDK,歡迎各位提出建議,謝謝!
          18. Qt入門書籍推薦霍亞飛的《Qt Creator快速入門》《Qt5編程入門》,Qt進階書籍推薦官方的《C++ GUI Qt4編程》。
          19. 強烈推薦程序員自我修養和規劃系列書《大話程序員》《程序員的成長課》《解憂程序員》,受益匪淺,受益終生!
          20. SDK地址:https://gitee.com/feiyangqingyun/QUCSDK https://github.com/feiyangqingyun/qucsdk

          原文鏈接:https://www.cnblogs.com/feiyangqingyun/p/11665022.html

          【領QT開發教程學習資料,點擊下方鏈接莬費領取↓↓,先碼住不迷路~】

          點擊這里:「鏈接」


          主站蜘蛛池模板: 国产精品一区二区三区久久| 亚洲午夜精品一区二区| 红杏亚洲影院一区二区三区| 国产亚洲一区二区在线观看| 国产成人精品一区二区三在线观看| 中文人妻无码一区二区三区| 日本一区二区在线不卡| 亚洲乱码一区av春药高潮| 国产午夜精品一区二区三区不卡| 国产成人av一区二区三区在线| 日韩一区二区视频| 国产精品揄拍一区二区| 亚洲宅男精品一区在线观看| 91精品一区二区综合在线| 亚欧色一区W666天堂| 国产爆乳无码一区二区麻豆| 中文字幕亚洲乱码熟女一区二区| 搜日本一区二区三区免费高清视频 | 亚洲AV无码一区二区乱子伦| 国产A∨国片精品一区二区| 国产精品盗摄一区二区在线| 在线视频亚洲一区| 后入内射国产一区二区| 精品一区二区高清在线观看| 免费在线观看一区| 国产高清精品一区| 综合久久一区二区三区 | 亚洲综合一区二区精品久久| 农村乱人伦一区二区| 精品欧洲AV无码一区二区男男 | 久久se精品一区二区影院| 久久无码一区二区三区少妇| 亚洲乱码一区二区三区在线观看| 国产午夜精品一区二区三区漫画 | 久久毛片一区二区| 国产精品99精品一区二区三区| 精品一区二区三人妻视频| 日韩一区二区三区视频久久| 中文无码AV一区二区三区| 人体内射精一区二区三区| 在线免费一区二区|