paip.提升用户体验--radio图片选择器 easyui 实现..

本文详细介绍了如何使用EasyUI框架实现Radio图片选择器,并通过一系列优化措施提升用户体验。包括数据获取、分页展示、绑定到grid、图片样式设置以及事件处理等关键步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

#paip.提升用户体验--radio图片选择器 easyui 实现..
===================================

##原因...
--------------------
首先,寻找这个控件,但是没有..
只好自己实现,使用Listview..
但是多少framework都没lv,只好使用datagrid来的做..



##.keyword,subtitle关键字,子标题
-------------------------
js json 字符串的转换.
列表 行转列 方法..
grid 列格式化..
datagrid >>> listview

作者 老哇的爪子 Attilax 艾龙,  EMAIL:1466519819@qq.com
来源: http://blog.youkuaiyun.com/attilax


##pseudo code伪码 处理流程
--------------------------

首先,捕获all json obj list
分页,5
line>> column..
绑定到个grid..(column 定义格式化到图片src)
设置图片边框,2px,normal:dot,color:gray   ,,,选择的:slot,color:red
设置mouse over,out event
获得值,,,一个是呈交的时候儿从slectpics pics 根据class..这个麻烦的..
一个是clieck的时候儿不个值放得个input里面,这个easy..





##actual code 实际代码如下
----------------
###捕获all json obj list
function getAjaxData()
{
var urlo4="data/defIcons.json";
  $.ajax({
            url:urlo4,
            dataType:"json",
            success:function(data){
             // $("#resText").html(date);
            // alert(data);
            //  alert(data[0]);
                //  var obj = eval(data);
                var obj=data;
                  logx("src::"+data[0].src);
                      var data2=Line2Col(data);
                    logx("line2col after:"+data2);
                    //return;
                //    var dataObjFmt=eval(data2);
                   addDataToGrid(data2);
                  
            }
       });
###
function Line2Col(data)
{
    var arrayObj = new Array();
    logx("dataarr.length:"+data.length);
    var arr = eval(data);  
    //arr=data;
    logx("<arr.length:"+arr.length);
for(var i=0;i<arr.length;i++){  
          var obj=arr[i];
          var s=obj.id+","+obj.src;
        
          arrayObj.push(s);
          if(i>=4)
              break;
   }  
    // arrayObj.push("testxxx");
     logx("arrayObjLeng:"+arrayObj.length);
     var s_r="";
     for(j=0;j<arrayObj.length;j++)
     {
         var s=arrayObj[j];
          var tmp=' "item@index": "@str"';
          tmp=tmp.replace("@index",j+1).replace("@str",s);
         s_r+=tmp+",";
        
     }
     s_r=s_r.substr(0,s_r.length-1);
      logx("s_r::"+s_r);
      s_r="[{"+s_r+"}]";
   return eval(s_r);
    
    
}

###bind to grid
function   addDataToGrid(data)
{$('#dg').datagrid({
            data: data,
            showHeader: false
            });
}

<table id="dg"  class="easyui-datagrid"    data-options="singleSelect:false" style="height:121px" >
    <thead>
    <tr>
      
 
   <th data-options="field:'item1' ,width:100,formatter:formatItem"  >item1</th>
     <th data-options="field:'item2' ,width:100,formatter:formatItem"  >部门名称</th>
       <th data-options="field:'item3' ,width:100,formatter:formatItem"  >部门名称</th>
         <th data-options="field:'item4' ,width:100,formatter:formatItem"  >部门名称</th>
           <th data-options="field:'item5' ,width:100,formatter:formatItem"  >item5</th>
 

    </tr>
    </thead>
    
</table>

 
function formatItem(val,row)
{
    var itemval=val;
    try{
    var a=val.split(",");
    var id=a[0];
    var src=a[1];
    }catch(e){}
    return '<div ><img id="icon_divO4_'+id+'"  class="img_def" onmouseover="over_event(this.id)" onmouseout="mouseout_event(this.id)" src="'+src+'" onclick="selectIcon('+id+')" /></div>';
    
}    
###set mouseout_event mouseover event
 <style type="text/css">
 
.img_def {
    
    border: 2px dotted #CCC;
}
 .over {
    border: 2px solid #F30;
}
.img_over {
    
    border: 2px solid #F30;
}
</style>

function mouseout_event(id)
{
$("#"+id).attr("class","img_def");    
}
function over_event(id)
{
$("#"+id).attr("class","img_over");    
}

### set click event
function selectIcon(id)
{
//alert(id);    
logx("slctIconId:"+id);
$("#selctIconId").attr("value",id);
}  
      
### PAIP编程珠玑中的示例代码解释 PAIP(Paradigms of Artificial Intelligence Programming)是一本深入探讨人工智能编程范式的书籍,其中包含了大量 Lisp 编写的程序实例。这些例子不仅展示了如何实现特定的人工智能算法,还提供了关于良好软件工程实践的重要见解。 #### 示例:通用求解器框架 书中介绍了一个名为 `defun` 的宏来定义函数,在构建通用问题解决器时非常有用[^1]: ```lisp (defun solve (problem) "Find a solution to the given problem." (let ((solution nil)) ;; Attempt to find a solution using backtracking. (labels ((try-next-option () (when (not solution) (if (no-more-options-p ()) (return-from try-next-option nil) (let* ((option (next-option))) (cond ((goal-reached-p option) (setf solution option)) (t (push-state option) (solve problem) (pop-state)))))))) (try-next-option) solution))) ``` 这段代码实现了回溯法解决问题的一般模式。通过递归调用自身并尝试不同的选项直到找到解决方案为止。如果当前路径无法通向目标,则会恢复之前的状态继续探索其他可能性。 此方法能够有效地处理许多复杂的组合优化类问题,并且由于其灵活性可以很容易地适应各种具体应用场景下的需求变化。 #### 示例:自然语言理解模块 另一个重要的部分涉及到了自然语言处理技术的应用案例——基于语法分析树结构来进行语义解析: ```lisp (defun parse-sentence (sentence) "Parse SENTENCE into its constituent parts and build an interpretation tree." (multiple-value-bind (subject verb-object) (split sentence 'verb) `(sentence :subject ,(parse-noun-phrase subject) :action ,verb-object))) (defun parse-noun-phrase (np-string) "Interpret NP-STRING as either a simple noun or compound phrase." ...) ``` 上述片段演示了如何将输入字符串分割成主谓宾成分,并进一步解析名词短语的具体含义。这种层次化的表示方式有助于后续更高级别的推理操作以及对话管理等功能的设计与实现。 #### 示例:专家系统规则引擎 最后值得一提的是书中对于专家系统的讨论,特别是有关于事实库管理和匹配机制的部分: ```lisp (defstruct fact id pattern bindings) (defun match-patterns (pattern facts) "Return all FACTS that unify with PATTERN, along with their BINDINGS." ...) (defun add-fact (kb new-fact) "Add NEW-FACT to knowledge base KB after checking consistency against existing rules." ...) ``` 这里展示了一种简单而有效的知识表达形式及其相应的查询接口设计思路。通过对模式进行统一化计算从而快速定位符合条件的事实条目;而在更新数据库前则需确保新加入的信息不会引起逻辑矛盾等问题的发生。 以上仅是从《Programming Pearls》一书摘取的一些精彩片段,实际上该著作涵盖了更为广泛的内容领域和技术细节等待读者去发掘学习。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值