javascript - 重写 JS 中的赋值运算符

标签 javascript cookies

var myObject = {"myKey" : "myValue"}
typeof(myObject.myKey) returns `string`

myObject.myKey = "newValue"
console.log(myObject.myKey) prints newValue

这是预期的行为。但是,类似的值写入不适用于 document.cookie

typeof(document.cookie) returns `string`

但执行 document.cookie = "value=123" 时,附加到 document.cookie 字符串而不是将其值设置为 value=123

那么,如何覆盖对 document.cookie 的赋值?

最佳答案

document.cookie 有点神奇,但根据您的浏览器限制,您可以使用 Object.defineProperty定义具有不同getset 行为的属性。

例如:

var obj = {};

Object.defineProperty(obj, "data", {
    get: function() {return this.val; },
    set: function(val) { this.val = JSON.stringify(val); }
});

obj.data = {a:1}; // Set as an object...
console.log(obj.data) // but retrieve as string '{"a":1}'

例如,要执行类似于 cookie 示例的操作,您可以创建如下函数:

var mixinExtender = (function mixinExtender(target) {
  var rawValue = {};

  Object.defineProperty(target, "data", {
    get: function() { return JSON.stringify(rawValue); },
    set: function(val) { 
      for(var key in val) {
        rawValue[key]  = val[key];
      }
    }
  });
})

这将混入一个 data 属性,该属性会将 setter 值扩展到一个私有(private)对象中。 getter 将返回它的序列化版本。然后你可以使用它:

var obj = {};
mixinExtender(obj);

obj.data = {a:1};      // Add "a" key
obj.data = {b:2};      // Add "b" key
console.log(obj.data)  // > {"a":1,"b":2} 

关于javascript - 重写 JS 中的赋值运算符,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22309585/

相关文章:

java - 如何在 ELB 中使用 aws 应用程序生成的 session 粘性

cookies - addCookie 方法抛出 'addCookie called with non-cookie parameter'

Python - 成功使用 Cookie

javascript - AppBrowser 中 Cordova 的回调事件

javascript - 未正确读取 Jquery Cookie

java - 如何以编程方式登录到 URL、保持 session 并浏览到不同的页面

javascript - 迭代 boolean 值的二维数组并返回基于 true/false 的递增值

javascript - 创建类似于移动 Gmail 的固定容器

Javascript - 输出对象方法的返回值

javascript - react - onclick 使用事件而不使用箭头功能