随着avalon的普及,越来越多人加入avalon的大家庭。随之而来的是各种问题。本文在这里统一解答一下。

使用avalon基本上有几个方针要坚持

  • 数据必须先定义后使用,只能VM中定义,不能V中定义。
  • 数据必须先打扁后使用,比如对象的层次不宜太深,数组不能太长。
  • 页面上不使用太复杂的逻辑,需要的话请封装成函数,也方便自己或后人维护调试。
  • IE下方法名,属性名注意不区分大小写(因为是VBS)。
  • IE下方法中的this不一定指向自身。
  • avalon在domReady时自己执行了一次scan,对于后插入的DOM结构,需要自己手动scan。

SCRIPT1028: 缺少标识符、字符串或数字

这只发生于IE6-7,它不支持对象最后一个键值对后面添加逗号,如

  1. vm.$bOpts = {
  2. header: "提示信息title",
  3. content: "提示信息content",
  4. }

SCRIPT1041: 名称重定义

这是avalon在IE6-8使用VBScript对象创建VM对象引起的,VB对象不支持为对象添加两个相同的属性名

  1.  
  2. avalon.define("test", function(vm){
  3. vm.aaa = 1
  4. avalon.mix(vm, {
  5. aaa: 2, //这里出问题了
  6. bbb: 3
  7. })
  8. })

此外,由于VBScript变量名不区分大小写

  1.  
  2. vm.user = {username: 'lili', userName: 'lilililili'}

这样也会报名称重定义 Error!

异步重写空对象出错

这是用法问题

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <title>TODO supply a title</title>
  5. <meta charset="UTF-8">
  6. <meta name="viewport" content="width=device-width">
  7. <script src="avalon.js" type="text/javascript"></script>
  8. <script>
  9. var model = avalon.define("test", function(vm) {
  10. vm.data = {}
  11. })
  12. setTimeout(function() {
  13. var data = {
  14. a: 1,
  15. b: 2,
  16. c: 3
  17. }
  18. model.data = data //这样正常
  19. // avalon.mix(model.data, data) //这样会报错
  20. }, 1000)
  21. </script>
  22. <style>
  23. #aaa{
  24. width: 100%;
  25. height:200px;
  26. background:green;
  27. }
  28. </style>
  29. </head>
  30. <body ms-controller="test">
  31. <input ms-duplex="data.a"/>
  32. </body>
  33. </html>

事件回调的this对象$model, $vmodels不见了的问题

1.3.5已经废掉, 源码搜data.param.replace(/-\d+$/, "") ,加上这几行

  1. try{
  2. elem.$vmodel = vmodels[0]
  3. elem.$vmodels = vmodels
  4. }catch(e){}

或者通过ms-click=callback(avalon.vmodels.xxx)传入你的$vmodel

放在button标签的事件点击没有生效

button标签默认会提交页面,产生跳转,因此需要指定type="button",即<buttton type=button ms-click=check >

显示隐藏切换失败

  1. <div class="inp,inte" ms-visible="integralCount > 0 && intergralCount > maxIntegral + spendIntegral" >
  2. 已超出可使用积分({{maxIntegral/100}}元),请重新输入
  3. <div>

原因,不要在视图的指令里面写&& , ||, 请封装为函数

  1. <div class="inp,inte" ms-visible="isVisible(integralCount, maxIntegral ,spendIntegral)" >
  2. 已超出可使用积分({{maxIntegral/100}}元),请重新输入
  3. <div>

交互数组中两个元素的位置失败

原因,只能通过数组方法,比如splice进行移出插入操作

  1. <!DOCTYPE html>
  2. <html lang="zh-cn">
  3. <head>
  4. <title>
  5. Avalon splice issue
  6. </title>
  7. <meta charset="utf-8">
  8. </head>
  9. <body>
  10. <ul ms-controller="test">
  11. <li ms-repeat="items">{{ el.name }}</li>
  12. </ul>
  13. <script src="avalon.js"></script>
  14. <script>
  15. var test = avalon.define('test', function(vm) {
  16. vm.items = [
  17. {
  18. name: 'First lady'
  19. },
  20. {
  21. name: 'Second boy'
  22. },
  23. {
  24. name: 'Third guy'
  25. }
  26. ];
  27. });
  28.  
  29. var temp = test.items.splice(2, 1);
  30. test.items.splice(1, 0, temp[0].$model);//如果是简单数据类型,就不需要.$model
  31. </script>
  32. </body>
  33. </html>

IE6-8下报window.execScript 这一行错误

可能是你的VM上定义了一个很大的数组引发的

vm.err大IE6-8下报错

type, err, erm, me是VBScript关键字

ms-controller="aaa",aaa这个VM只能应用一个元素上,页面上不能 出现一个VM同时应用于两个元素

低版本IE使用VBScript,不支持未婚先孕!

如有更多问题,请统一在这里提 https://github.com/RubyLouvre/avalon/issues/509

avalon的常见问题的更多相关文章

  1. 迷你MVVM框架avalon在兼容旧式IE做的努力

    很多时候,写代码就像砌砖头,只要我们不关心盖楼的原因.建筑的原理.土木工程基础和工程经验,就算我们砌了100栋高楼,我们也就只是一个砌砖工人,永远也成为不了一个工程师,更别说建筑师了.而那些包工头也只 ...

  2. MVVM框架avalon在兼容旧式IE

    迷你MVVM框架avalon在兼容旧式IE做的努力 当前标签: avalon 共3页: 1 2 3 下一页  迷你MVVM框架avalon在兼容旧式IE做的努力 司徒正美 2014-03-13 11: ...

  3. 【小梅哥SOPC学习笔记】SOPC开发常见问题及解决办法集锦

    SOPC开发常见问题及解决办法集锦 一.Symbol 'NULL' could not be resolved 近期在评估使用NIOS II处理器进行项目的开发,我使用的软件是Quartus II 1 ...

  4. C++常见笔试面试要点以及常见问题

    1. C++常见笔试面试要点: C++语言相关: (1) 虚函数(多态)的内部实现 (2) 智能指针用过哪些?shared_ptr和unique_ptr用的时候需要注意什么?shared_ptr的实现 ...

  5. SQL Server常见问题介绍及快速解决建议

    前言 本文旨在帮助SQL Server数据库的使用人员了解常见的问题,及快速解决这些问题.这些问题是数据库的常规管理问题,对于很多对数据库没有深入了解的朋友提供一个大概的常见问题框架. 下面一些问题是 ...

  6. 【腾讯优测干货分享】如何降低App的待机内存(二)——规范测试流程及常见问题

    本文来自于腾讯优测公众号(wxutest),未经作者同意,请勿转载,原文地址:https://mp.weixin.qq.com/s/806TiugiSJvFI7fH6eVA5w 作者:腾讯TMQ专项测 ...

  7. MVVM大比拼之avalon.js源码精析

    简介 avalon是国内 司徒正美 写的MVVM框架,相比同类框架它的特点是: 使用 observe 模式,性能高. 将原始对象用object.defineProperty重写,不需要用户像用knoc ...

  8. mysql数据库开发常见问题及优化

    mysql 数据库是被广泛应用的关系型数据库,其体积小.支持多处理器.开源并免费的特性使其在 Internet 中小型网站中的使用率尤其高.在使用 mysql 的过程中不规范的 SQL 编写.非最优的 ...

  9. MVC、MVP、MVVM、Angular.js、Knockout.js、Backbone.js、React.js、Ember.js、Avalon.js、Vue.js 概念摘录

    注:文章内容都是摘录性文字,自己阅读的一些笔记,方便日后查看. MVC MVC(Model-View-Controller),M 是指业务模型,V 是指用户界面,C 则是控制器,使用 MVC 的目的是 ...

随机推荐

  1. 洛谷1352没有上司的舞会——树型dp

    题目:https://www.luogu.org/problemnew/show/P1352 #include<iostream> #include<cstdio> using ...

  2. Android 禁止系统进入深度休眠

    在Linux系统中,wake_lock是一直锁机制,只要有驱动占用这个锁,系统就不会进入深度休眠. 获取此锁的方法有两种: 1.在adb中通过指令获取wake_lock,系统就不会进入深度休眠 ech ...

  3. Openfiler使用说明

    Openfiler使用说明 http://www.cnblogs.com/zb9222/p/6118074.html 一. Openfiler简介 Openfiler 能把标准x86/64架构的系统变 ...

  4. js 正则用空格分割字符串

    var filename = "ASDFK*SADF+ALDLAS-LDKFADFa*seAc tion.java";var arr = filename.split(/\*|\- ...

  5. WebForm Response和Request以及Cookie

    Session:每一台电脑访问服务器,都会是独立的一套session,key值都一样,但是内容都是不一样的 以上所有内容,都跟cookies一样, 内置对象:用于页面之间的数据交互 为什么要使用这么内 ...

  6. Java堆外内存之四:直接使用Unsafe类操作堆外内存

    在nio以前,是没有光明正大的做法的,有一个work around的办法是直接访问Unsafe类.如果你使用Eclipse,默认是不允许访问sun.misc下面的类的,你需要稍微修改一下,给Type ...

  7. zabbix批量添加SNMP监听H3C端口检测以及流量图

    由于之前网络设备不是很多,监控网络设备接口就直接使用模版中的item来实现了,可是现在公司上线了一大批网络设备,如果要每个网络设备都做模板,添加item......那就该废了,于是迫于压力今天来测试使 ...

  8. 在控制终端输入AT命令

    控制台终端输入AT命令到smd8,步骤如下: 1. 先执行命令 cat /dev/smd8 & 2. 再执行  echo  -e  "ati\r\n"  > /dev ...

  9. 学习MongoDB 二:MongoDB添加、删除、修改

    一.简介 MongoDB是一个高性能,开源,无模式的文档型数据库,是当前NoSQL数据库产品中最热门的一种.数据被分组存储在数据集中,被称为一个集合(Collenction)和对于存储在MongoDB ...

  10. Sublime Text 3 个人使用总结

    待更新 Sublime Text 3\Packages\FileHeader\template\header