跳到主要內容

精選文章

【公開聲明】關於近期網路特定言論與個資洩漏事件的說明

大家好,我是江舜智(紅色死神)。 近期有許多長期關注我的朋友、學生以及合作夥伴向我反映,網路上有特定人士(Threads 帳號 @drama.note)持續在各類與事件無直接關聯的討論串、課程資訊以及公開貼文下方留言,並引導他人前往我的個人網站與公開平台,同時以負面標籤及特定敘事方式討論我個人。 由於相關行為已持續相當長一段時間,甚至延伸至現實生活層面,對我的合作單位、教學夥伴以及部分學生造成困擾與壓力,我對此感到遺憾,也對受到影響的朋友們表達歉意。 因此,我希望藉此機會向所有關心此事的朋友,說明我的立場與態度。 一、關於事件本身:理性討論永遠受到歡迎 多年來,不論是在軟體開發、網頁前端教學領域,或是經營「Uniform Map 制服地圖」、進行攝影創作與分享個人觀點時,我始終相信公開透明與理性交流的重要性。 我並非完美的人,任何人都可能有思慮不周或與他人意見不同的時候。過去關於網站經營模式與相關議題,網路上確實出現過不少討論與質疑,而相關事項也曾進入司法程序接受調查。 經檢察機關完整調查後,最終依法作出不起訴處分,案件已告確定。 這代表相關指控經過司法審查後,並未認定存在違法情事。即使如此,我仍然願意以開放的態度面對外界意見。 如果有人對於我的教學內容、網站運作方式,或任何公開言論抱持不同看法,我始終歡迎在尊重彼此的前提下進行公開且理性的討論。 若有任何值得檢討與改進之處,我也願意虛心接受建設性的批評與建議。 二、關於持續性的騷擾行為:應以事實與法律為依據 我認為理性討論與持續性騷擾之間,存在明確界線。 近一年來,特定人士的部分行為已不再只是針對議題提出意見,而是逐漸演變成持續性的人身攻擊與現實層面的干擾,包括: • 在與事件無直接關聯的課程公告、教學資訊及各類公開討論串中,反覆張貼我的個人資訊與相關內容。 • 主動聯繫我的合作單位與工作相關機構,對其施加壓力或進行干擾。 • 在司法程序進行期間及收到相關通知後,仍持續以指名道姓方式發布涉及人格評價與攻擊性的言論。 我尊重每個人表達意見與監督公共議題的權利,但我同樣認為,任何討論都應建立在事實基礎上,並尊重法律程序與他人的基本權益。 無論支持或反對我的人,都有權自行查閱公開資訊、了解案件經過並形成自己的判斷,而不是透過片面標籤或情緒性指控來取代事實。 三、我的處理方式 對於相關爭議,我始終選擇透過法律與制度來處理,...

jQuery 實作類似 gmail 的 auto complete 效果

Auto Complete

最近想要弄一個類似gmail的auto complete效果,因為找了一堆plugin都沒有我想要的效果,所以就自己實作了,功能寫出來了,不知道有沒有bug就是了。

首先準備一個類似下面的html
  1. <label for="select_usr">Select User: </label>  
  2. <div class="auto_com_block">  
  3.     <input type="text" id="select_usr" >  
  4.     <ul class="auto_com_result_list">  
  5.     </ul>  
  6. </div>  

auto complete的結果是放在一個ul內,再用position跳出dom去定位。

CSS如下
  1. label{   
  2.     padding-top:2px;   
  3.     font-size:14px;   
  4.     float:left;   
  5.     margin-right:10px;   
  6. }   
  7. .auto_com_block{   
  8.     position:relative;   
  9.     float:left;   
  10. }   
  11. .auto_com_result_list{   
  12.     position:absolute;   
  13.     left:0;   
  14.     top:20px;   
  15.     border1px solid #B5DFF4;   
  16.     padding:2px;   
  17.     background:#fff;   
  18.     display:none;   
  19. }   
  20. .auto_com_result_list li{   
  21.     padding:2px;   
  22.     background:#fff;   
  23.     width:190px;   
  24. }   
  25. .auto_com_result_list li.this_result{   
  26.     background:#def2ff;   
  27. }   
  28. .user_photo{   
  29.     float:left;   
  30.     margin-right:6px;   
  31.     height:36px;   
  32.     width:36px;   
  33.     overflow:hidden;   
  34. }   
  35. .user_data{   
  36.     float:left;   
  37.     width:140px;   
  38. }   
  39. .auto_com_result_list li img{   
  40.     height:36px;   
  41. }  

範例沒有放真的篩選後的資料,真的要實作到系統就用ajax的方法去取得結果就好了,這邊先用一個物件去放等等要顯示的內容。
  1. var data = [   
  2.           {'name' : 'Bruce',   
  3.            'email' : '[email protected]',   
  4.            'picture' : 'pic.jpg'},   
  5.           {'name' : 'Jack',   
  6.            'email' : '[email protected]',   
  7.            'picture' : 'pic2.jpg'},   
  8.            {'name' : 'Jason',   
  9.            'email' : '[email protected]',   
  10.            'picture' : 'pic3.jpg'},   
  11.            {'name' : 'Tom',   
  12.            'email' : '[email protected]',   
  13.            'picture' : 'pic4.jpg'},   
  14.            {'name' : 'Jessica',   
  15.            'email' : '[email protected]',   
  16.            'picture' : 'pic5.jpg'},   
  17.            {'name' : 'Andrew',   
  18.            'email' : '[email protected]',   
  19.            'picture' : 'pic.jpg'},   
  20. ];  

我用滑鼠hover或鍵盤上下鍵選取篩選後的結果,所以就不用css的:hover去highlight選取的使用者,而是用js去控制,並把選取的結果記錄下來,下面這段是紀錄選取後要highlight的項目的。
  1. $resultUsr=0; //focus on first result      
  2. function thisResult(){   
  3.     $(".auto_com_result_list li").removeClass("this_result").eq($resultUsr).addClass("this_result");   
  4. }   
  5. thisResult();  

然後就是在按enter或滑鼠點選時,要把值給丟到input欄位內的function
  1. //get value from auto complete   
  2. function getUser(num){   
  3.     $selectUser=data[num].name;   
  4.     $(".sender_name").val($selectUser);   
  5.     $(".auto_com_result_list").hide();   
  6.     $resultUsr=0;   
  7.     thisResult();   
  8. }  

最後就是判斷按鍵盤或滑鼠需要去highlight以及取得值,就大功告成了。
  1. $(".auto_com_result_list li").hover(function(){   
  2.     $resultUsr=$(this).index();   
  3.     thisResult();   
  4. });   
  5. //get value from auto complete by mouse event   
  6. $(".auto_com_result_list li").click(function(){   
  7.     getUser($resultUsr);   
  8. });   
  9.     //get value from auto complete by key event    
  10. $("#select_usr").keyup(function(e){   
  11.     if($(this).val()!=""){   
  12.         thisResult();   
  13.         $(".auto_com_result_list").show();   
  14.         if(e.keyCode==40){ //down   
  15.             if($resultUsr < $resultLength-1){   
  16.                 $resultUsr=$resultUsr+1;   
  17.                 thisResult();   
  18.             }   
  19.         }else if(e.keyCode==38 && $resultUsr > 0){   
  20.             $resultUsr=$resultUsr-1;   
  21.             thisResult();   
  22.         }else if(e.keyCode==13){   
  23.             getUser($resultUsr);   
  24.         }else{   
  25.             $resultUsr=0;   
  26.             thisResult();   
  27.         };         
  28.     }else{   
  29.         $resultUsr=0;   
  30.         thisResult();   
  31.         $(".auto_com_result_list").hide();         
  32.     }   
  33. });   

DEMO

留言

熱門文章