手机调试、webview跳转、vue基础

前言

实习一周,学到很多东西,技术上的,心态方面的,还有时间管理方面等等。我想,我会很怀念这一周的。

技术上总结

公司前端主要的技术栈是vue和mui,vue自己之前不熟悉,也是慢慢在学习之中(这对自己来讲,是一个锻炼的机会,也是一个很大的挑战)。mui之前也没有接触,所以还是很大的难度的。

mui手机端调试

ctrl+r快捷键为运行和停止,可以直接使用数据线连接手机进行调试,一开始自己的手机不行,后来又一次重启后发现可用了(这不得不说是一个坑,我的猜想可能是重启删除了一些不必要的文件)

webview实现页面之间的交互

先放代码
主页面:

var repertoryHtml = plus.webview.create("repertory_matter_gp.html", "repertoryId", {
    width: '100%',
    height: '100%',
    margin: "auto",
    scalable: false
}, {
    reqDetailId: reqDetailId,
    warehouseList: warehouseList
});

repertoryHtml.addEventListener("loaded", function () {
    repertoryHtml.show('fade-in', 300);
    repertoryHtml = null;
}, false);

解析:可以通过plus.webview.create创建一个新的页面,其中第一个参数是页面的路径,第二个参数是id,第三个参数是样式,第四个就是传给下个页面的参数。
第二段代码中,使用addEventListener监听loaded事件,实现它的一个过渡效果。
次页面:

//使用webview取得上一个页面中返回的值
var currentWebview = plus.webview.currentWebview();
console.log(currentWebview.reqDetailId);
var reqDetailId = currentWebview.reqDetailId;
var warehouseList = currentWebview.warehouseList;
console.log(warehouseList);

通过webview取得上个页面传过来的参数,这样的方法实现很巧妙。(实践证明,可以穿对象还有变量,还有数组)

//取得父页面
var parentWebview = plus.webview.currentWebview().opener(); // 获取父窗口webview
//通过mui.fire()方法可触发目标窗口的自定义事件
mui.fire(parentWebview, "finishSelect", {
    responseObj: responseObj
});
mui.back();

再次通过webview将参数传回去,注意这里取得父页面的方式:plus.webview.currentWebview().opener()

window.addEventListener('finishSelect', function (e) {  //获取参数值
            var responseObj = e.detail.responseObj;
            console.log(JSON.stringify(responseObj));
        }

通过监听finishSelect这个事件,从而取得上个页面传回来的值。
关于webview,自己还是刚刚接触,觉得是页面传参数的一个不错的选择。

vue的小知识归纳总结

创建vue实例

var vm = new Vue({
  // 选项
})

每个 Vue 实例都会代理其 data 对象里所有的属性
这一点很重要,也就是可以通过vue实例取得视图中数据的重要的一步(我觉得vue这样设计就是为了更好的实现这个效果)

Vue.nextTick(callback)

先看例子(来源是官网)

<div id="example">{{message}}</div>

var vm = new Vue({
  el: '#example',
  data: {
    message: '123'
  }
})
vm.message = 'new message' // 更改数据
vm.$el.textContent === 'new message' // false
Vue.nextTick(function () {//DOM操作结束后执行下面的逻辑
  vm.$el.textContent === 'new message' // true
})

个人的简单理解就是之前修改的视图上面的数据已经执行之后,再去执行nextTick里面的业务逻辑

vue——$set

this.$set(this.items[j], 'send', temp);
this.$set(this.items[j],'checked',true);

设置对象的属性。如果对象是响应式的,确保属性被创建后也是响应式的,同时触发视图更新。这个方法主要用于避开 Vue 不能检测属性被添加的限制。
注意对象不能是 Vue 实例,或者 Vue 实例的根数据对象.

个人理解:当data里面的 对象新创建了一个属性的时候,应该确保将这个这个属性能够反映到视图上,所以要用到$set。

关于v-bind和v-model

v-bind的缩写就是:
v-model的一个主要用法在于表单控件上面的创建双向数据绑定,这个在项目总自己也猜到了大坑。

<input v-model="something">
<input
   v-bind:value="something"
   v-on:input="something = $event.target.value">

v-on

  • v-on的缩写是@
  • 常用方法总结
//方法处理器
<button v-on:click="doThis"></button>
//dothis为一个方法 
//缩写 
<button @click="doThis"></button>
  • 在监听原生 DOM 事件时,方法以事件为唯一的参数。如果使用内联语句,语句可以访问一个 $event 属性: v-on:click="handle('ok', $event)"
//内联语句
<button v-on:click="doThat('hello', $event)"></button>

零散知识

  • 跳转方法之一
window.location.href = "index.html"
  • 怎样通过url传参数
  • success : 当请求成功时调用的函数。这个函数会得到一个参数:从服务器返回的数据。当请求成功时调用函数,即status==200。
  • complete :当请求完成时调用的函数。这个函数会得到两个参数:XMLHttpRequest对象和一个描述请求成功的类型的字符串。当请求完成时调用函数,即status==404、403、302...。
  • stringify()用于从一个对象解析出字符串,parse用于从一个字符串中解析出json对象
complete
meta
  • meta标签


    meta标签

心态

  • 遇到问题不可怕,不畏失败,将重心放到解决问题上
  • 不懂的虚心请教他人
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 这篇笔记主要包含 Vue 2 不同于 Vue 1 或者特有的内容,还有我对于 Vue 1.0 印象不深的内容。关于...
    云之外阅读 5,082评论 0 29
  • 下载安装搭建环境 可以选npm安装,或者简单下载一个开发版的vue.js文件 浏览器打开加载有vue的文档时,控制...
    冥冥2017阅读 6,095评论 0 42
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,991评论 19 139
  • 秋之随想 秋分过后,各个品种的玉米陆续成熟。原本密不透风的青纱帐悄然变身,似乎一夜之间遍染金黄。而后飒飒的风声把这...
    益德居士阅读 341评论 4 6
  • 美丽的海滨小城——威海,感谢上天,让我阴差阳错地遇见。
    半梦半醒jxl阅读 251评论 1 1