跳到主要內容

精選文章

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

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

AngularJS UI Bootstrap 製作自動提示輸入效果- Typeahead

Typehead

google 搜尋的時候,輸入一些字後就會有下拉建議的字,這個現在用 AngularJS 搭配 UI Bootstrap 做起來也很方便。

首先到 Angular UI Bootstrap 下載該下載的 css 和 js,或直接用 CDN。
  1. <link href="http://netdna.bootstrapcdn.com/twitter-bootstrap/2.3.2/css/bootstrap.min.css" rel="stylesheet">  
  2. <script src="http://ajax.googleapis.com/ajax/libs/angularjs/1.0.8/angular.js"></script>  
  3. <script src="http://angular-ui.github.io/bootstrap/ui-bootstrap-tpls-0.6.0.js"></script>  

基本用法:
  1. <input type="text" ng-model="selected" typeahead="state for state in states | filter:$viewValue | limitTo:8" class="form-control">  

然後在 controller 裡放 json 格式的資料
  1. $scope.states = ['Alabama''Alaska''Arizona''Arkansas''California''Colorado''Connecticut''Delaware''Florida''Georgia''Hawaii''Idaho''Illinois''Indiana''Iowa''Kansas''Kentucky''Louisiana''Maine''Maryland''Massachusetts''Michigan''Minnesota''Mississippi''Missouri''Montana''Nebraska''Nevada''New Hampshire''New Jersey''New Mexico''New York''North Dakota''North Carolina''Ohio''Oklahoma''Oregon''Pennsylvania''Rhode Island''South Carolina''South Dakota''Tennessee''Texas''Utah''Vermont''Virginia''Washington''West Virginia''Wisconsin''Wyoming'];  

方便的是還可以自己寫 template 基本用法也很簡單。

我準備這樣的 json
  1. $scope.belongData = [{   
  2.         "name""Captain America",   
  3.         "group""Marvel",   
  4.         "img""captain_america.png"  
  5.       },   
  6.       {   
  7.         "name""Daredevil",   
  8.         "group""Marvel",   
  9.         "img""daredevil.png"  
  10.       },   
  11.       {   
  12.         "name""The Flash",   
  13.         "group""DC COMIC",   
  14.         "img""flash.png"  
  15.       },   
  16.       {   
  17.         "name""Green Lantern",   
  18.         "group""DC COMIC",   
  19.         "img""greenlantern.png"  
  20.       },   
  21.       {   
  22.         "name""Hulk",   
  23.         "group""Marvel",   
  24.         "img""hulk.png"  
  25.       },   
  26.       {   
  27.         "name""Ironman",   
  28.         "group""Marvel",   
  29.         "img""ironman.png"  
  30.       },   
  31.       {   
  32.         "name""Silver Surfer",   
  33.         "group""Marvel",   
  34.         "img""silversurfer.png"  
  35.       },   
  36.       {   
  37.         "name""Spider Man",   
  38.         "group""Marvel",   
  39.         "img""spiderman.png"  
  40.       }   
  41.       ,   
  42.       {   
  43.         "name""Thor",   
  44.         "group""Marvel",   
  45.         "img""thor.png"  
  46.       }   
  47. ];  

html 則是這樣
  1. <input type="text" ng-model="belongSelected" placeholder="Custom template" typeahead="belong as belong.name for belong in belongData | filter:{name:$viewValue}" typeahead-template-url="belongFilter.html" class="form-control">  

從指定的 json 內找特定的資料,裡面有一個 typeahead-template-url 就是用來放自訂的樣式的,template 的寫法如下

  1. <script type="text/ng-template" id="belongFilter.html">   
  2.   <li class="list" >   
  3.     <div class="char_img">   
  4.       <img ng-src="{{match.model.img}}">   
  5.     </div>   
  6.     <div class="cha_name">{{match.model.name}}</div>   
  7.     <div class="cha_group">{{match.model.group}}</div>      
  8.   </li>   
  9. </script>  

把對應的值塞到想塞的地方,再調整樣式就可以了。

Demo

留言

熱門文章