FineUI(专业版)升级指南

升级其实很简单,仅支持从FineUI(开源版)v4.2+ 升级!

升级到专业版

升级

升级需预留足够的测试时间,确保所有功能正常工作!


注:
  • jQuery引用 全部 删除(专业版已经包含最新的jQuery引用);
  • 第三方和用户自定义脚本 全部 放在 </form> 标签的后面;
  • Window、Menu、HiddenField 控件 全部 放到 </form> 标签的前面,不要放到任何控件中;
  • 使用 Visual Studio 的 Nuget 管理器下载最新的 Newtonsoft.Json 库;
  • 更多 FineUI 相关的常见问题

经过上面的几部操作,你已经完成了 95% 的升级工作,接下来就要进行详细的测试!


常见问题的解决办法(展开全部):
  • 仅支持从开源版v4.2+升级!

    如果你的项目基于FineUI(开源版)的版本低于v4.2,请先升级到开源版的最高版本,然后再升级到专业版。

  • JavaScript 错误:'_updateDatepicker' undefined(删除所有jQuery引用)

    由于FineUIPro中已经包含了最新的jQuery引用,因此你需要在整个项目中查找并删除jQuery引用,重复加载jQuery会导致未知的错误。

  • HTML5文档类型
    如果项目中页面有类似如下的头部定义:
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml">
    <head>
    请统一替换为HTML5文档类型:
    <!DOCTYPE html>
    <html>
    <head>
  • res.axd?js=f_all.js 404 (Not Found)
    1. 首先确保Web.config中正确配置了httpHandlers,类似:
      <httpHandlers>
        <add verb="GET" path="res.axd" type="FineUIPro.ResourceHandler, FineUIPro" validate="false" />
      </httpHandlers>
    2. 如果使用了Forms Authentication,还要添加res.axd的例外项,类似:
      <location path="res.axd">
      	<system.web>
      	  <authorization>
      		<allow users="*" />
      	  </authorization>
      	</system.web>
      </location>
    更加详细的配置参数,请参考文档或者示例项目。
  • HtmlEditor不显示

    FineUI(专业版)的富文本编辑器可以在UMEditor、UEditor、CKEditor、TinyMCE中间选择,通过控件属性Editor, BasePath来进行切换,详见示例

  • Nuget程序包还原失败:找不到...的程序包FineUIPro

    由于开源版是从 NuGet下载的 FineUI.dll,而专业版需要自行引用 FineUIPro.dll,所以需要从项目根目录的 packages.config 文件中删除 FineUIPro 项。

  • 未找到请求的值“Neptune”
    在将“Neptune”字符串转换为 Theme 枚举类型时发生了错误,由于专业版中已经不包含Neptune主题,因此你可能需要在代码层面进行保护,类似:
    try
    {
    	string themeValue = themeCookie.Value;
    	pm.Theme = (Theme)Enum.Parse(typeof(Theme), themeValue, true);
    }
    catch (Exception)
    {
    	pm.Theme = FineUIPro.Theme.Default;
    }
  • 所有图标丢失
    1. 确保项目的请求和响应都是 UTF-8 编码,在Web.config中,你可能需要添加:
    <globalization requestEncoding="utf-8" responseEncoding="utf-8" fileEncoding="utf-8"/>

    2. 确保 icon 目录位于 res 目录下面。
  • 树节点图标丢失
    在代码和页面查找 EnableIcons 属性,将其设为 true。
  • JavaScript 错误:object/i is not a function
    检查页面的自定义 JavaScript 是否存在如下代码:
    leftRegion.addTool({
    	type: 'gear',
    	tooltip: '系统设置',
    	regionTool: true,
    	handler: function (event, toolEl, panelHeader) {
    		// ....
    	}
    });
    						
    如果存在,请改为:
    leftRegion.addTool({
    	iconFont: 'gear',
    	tooltip: '系统设置',
    	handler: function () {
    		// ....
    	}
    });
    						
  • 自定义脚本更新列表(JavaScript)
    由于FineUI(专业版)完全抛弃了 extjs 库,因此如果你在项目中使用了自定义脚本,则有很多需要更新的地方,这里也仅仅列出了一小部分。
    1. 表格不存在 getStore, getSelectionModel, getPlugin, getView 等方法
      在项目中查找所有的 getStore 字符串,这些地方都需要你手工一个一个的更新。
      比如之前用来展开全部扩展列的客户端脚本是:
      function expandAllRows() {
      	var grid = F(gridClientID);
      	var store = grid.getStore();
      	var expander = grid.getPlugin(gridClientID + '_rowexpander');
      	for (var i = 0, count = store.getCount() ; i < count; i++) {
      		var record = store.getAt(i);
      		expander.toggleRow(i, record);
      	}
      }
      专业版中需要改为:
      function expandAllRows() {
      	F(gridClientID).expandRowExpanders();
      }
    2. 查找所有的 .x-grid-row 替换为 .f-grid-row
      CSS类名的前缀全部由 x 改为 f,类似的改动还有:
      • .x-grid-cell -> .f-grid-cell
      • .x-grid-row-selected -> .f-grid-row-selected
      • .x-grid-row-summary -> .f-grid-row-summary
      • .x-panel-body -> .f-panel-body
    3. 表格行的右键菜单事件名称由 beforeitemcontextmenu 改为 beforerowcontextmenu
      开源版中弹出表格右键菜单的代码为:
      F(gridID).on('beforeitemcontextmenu', function (view, record, item, index, event) {
      	F(menuID).showAt(event.getXY());
      	event.stopEvent();
      });
      在专业版,需要如下代码:
      F(gridID).on('beforerowcontextmenu', function (event, rowIndex) {
      	F(menuID).show();
      	// 返回false,来阻止弹出浏览器右键菜单
      	return false;
      });
    4. $(grid.el.dom) 改为 grid.el
      开源版中,通过 grid.el.dom 获取表格的容器DOM节点,$(grid.el.dom)获取相应的 jQuery 节点对象;
      专业版中,grid.el 返回的直接就是表格容器的 jQuery 节点对象。
    5. 获取下拉列表的显示文本,函数名由 f_getTextByValue 改为 getTextByValue
      一般用在可编辑单元格的 RendererFunction 中,用来由下拉列表的值获取显示的文本。
      开源版中:
      function renderGender(value) {
      	return F(ddlGenderID).f_getTextByValue(value);
      }
      专业版中:
      function renderGender(value) {
      	return F(ddlGenderID).getTextByValue(value);
      }
    6. 获取当前激活选项卡内IFrame的window对象更简单
      一般用在刷新当前激活选项卡内IFrame页面。
      开源版中:
      var iframeWnd = Ext.DomQuery.selectNode('iframe', mainTabStrip.getActiveTab().body.dom).contentWindow;
      iframeWnd.location.reload(false);
      专业版中:
      var iframeWnd = mainTabStrip.getActiveTab().getIFrameWindow();
      iframeWnd.location.reload(false);
    7. 获取单选按钮列表的选中值
      在开源版中,由于 extjs 本身没有提供方便的办法来获取和设置,所以 FineUI 进行了一定的封装,获取单选按钮列表的选中值的方法如下:
      开源版中:
      iconList.f_getSelectedValues()[0]
      专业版中:
      iconList.getValue()
      设置单选按钮列表的选中项,在开源版和专业版中分别为:
      开源版中:
      iconList.f_setValue('red')
      专业版中:
      iconList.setValue('red')
如果你在项目升级过程中遇到问题,请及时联系技术支持(QQ:2877408506)。
返回专业版首页

FineUI(专业版)由合肥三生石上软件有限公司荣誉出品!