Property Function

SpreadJS provides the Property Function, and the dot (".") operator to get properties of a JavaScript Object.

Description
app.vue
index.html
styles.css
Copy to CodeMine

For the PROPERTY function, you can get the value of the property of an object. The object properties follow JavaScript rules and are case sensitive. You can use PROPERTY function in a formula:
=PROPERTY(dataexpression, propertypath).

  • data_expression: Indicates object data. Accepts a cell reference whose value is an object or the result of an object function.
  • property_path: Indicates the property path in the object, the property path following the object depth.

The Dot Operator is a simplification of the PROPERTY function: the left value is the object or the reference to the object, the right value is the property value, which can be enclosed within quotes if it contains any invalid characters. It should be noted that Excel might throw errors with the Dot Operator.

For example:

sheet.setValue(0, 0, "User");
sheet.setValue(1, 1, "First Name");
sheet.setValue(1, 3, "Katy");
sheet.setValue(2, 1, "Age");
sheet.setValue(2, 3, 20);
sheet.setValue(3, 1, "Sex");
sheet.setValue(3, 3, "M");
sheet.setValue(4, 1, "Address");
sheet.setValue(5, 2, "Home");
sheet.setValue(5, 3, "Lodon");
sheet.setValue(6, 2, "Company");
sheet.setValue(6, 3, "China");

sheet.setFormula(9, 6, '=OBJECT(A1,OBJECT(B5,OBJECT(C6,D6,C7,D7),B2,D2,B3,D3,B4,D4))');
sheet.setFormatter(9, 6, '=@.User."First Name"'); // use dot operator in the formatter string
sheet.setFormula(9, 7, '=PROPERTY(PROPERTY(G10,"User"),"First Name")'); // "Katy"
sheet.setFormula(9, 8, '=PROPERTY(G10,"User.First Name")'); // "Katy"
sheet.setFormula(10, 8, '=PROPERTY(G10,"User.Address.Home")'); // "Lodon"
sheet.setFormula(10, 8, '=G10.User.Address.Home'); // "Lodon"
sheet.setFormula(12, 8, '=PROPERTY(G10,"Name")'); // "#N/A"
For the PROPERTY function, you can get the value of the property of an object. The object properties follow JavaScript rules and are case sensitive. You can use PROPERTY function in a formula: =PROPERTY(dataexpression, propertypath). data_expression: Indicates object data. Accepts a cell reference whose value is an object or the result of an object function. property_path: Indicates the property path in the object, the property path following the object depth. The Dot Operator is a simplification of the PROPERTY function: the left value is the object or the reference to the object, the right value is the property value, which can be enclosed within quotes if it contains any invalid characters. It should be noted that Excel might throw errors with the Dot Operator. For example:
<template> <div class="sample-tutorial"> <gc-spread-sheets class="sample-spreadsheets" @workbookInitialized="initSpread"> <gc-worksheet> </gc-worksheet> </gc-spread-sheets> </div> </template> <script> import Vue from 'vue'; import '@mescius/spread-sheets-vue' import GC from '@mescius/spread-sheets'; import './styles.css'; let App = Vue.extend({ name: "app", data: function () { return { spread: null }; }, methods: { initSpread: function (spread) { this.spread = spread; spread.options.allowDynamicArray = true; spread.setSheetCount(1); spread.suspendPaint(); spread.suspendCalcService(); this.initSheet1(spread.getSheet(0)); spread.resumeCalcService(); spread.resumePaint(); }, initSheet1(sheet) { sheet.suspendPaint(); sheet.name('WebService'); sheet.setColumnWidth(0,27); sheet.setColumnWidth(1,300); sheet.setColumnWidth(2,168); sheet.setColumnWidth(3,168); sheet.setValue(0, 1, 'Enter full or partial country name'); var inputStyle = new GC.Spread.Sheets.Style(); inputStyle.backColor = "#FEF3CD"; sheet.setStyle(1,1,inputStyle); sheet.setValue(3,1,"Name"); sheet.setValue(3,2,"Population"); sheet.setValue(3,3,"Language"); sheet.setValue(1,1,"united"); var headerStyle = new GC.Spread.Sheets.Style(); headerStyle.backColor = "rgb(222,235,246)"; headerStyle.font = "bold 11pt Calibri"; headerStyle.hAlign = 1; var borderBottom = new GC.Spread.Sheets.LineBorder; borderBottom.color = "black"; borderBottom.style = GC.Spread.Sheets.LineStyle.thin; headerStyle.borderBottom = borderBottom; sheet.setStyle(3,1,headerStyle); sheet.setStyle(3,2,headerStyle); sheet.setStyle(3,3,headerStyle); for (var r = 4; r < 50; r++) { //show the spilled objects as strings by using formatter property sheet.setFormatter(r,1,'=IFERROR(@.name, "")'); sheet.setFormatter(r,2,'#,##0'); sheet.setFormatter(r,3,'#,##0'); } sheet.setFormula(4,1,'=FILTERJSON(IF(LEN(B2)>3,WEBSERVICE("https://restcountries.com/v2/name/"&B2)))'); sheet.setFormula(4,2,'=B5#.population'); sheet.setFormula(4,3,'=B5#.languages.0.nativeName'); sheet.resumePaint(); } } }); new Vue({render: h => h(App)}).$mount('#app'); </script>
<!doctype html> <html style="height:100%;font-size:14px;"> <head> <meta charset="utf-8" /> <meta name="viewport" content="width=device-width, initial-scale=1.0" /> <link rel="stylesheet" type="text/css" href="$DEMOROOT$/en/vue/node_modules/@mescius/spread-sheets/styles/gc.spread.sheets.excel2013white.css"> <!-- SystemJS --> <script src="$DEMOROOT$/en/vue/node_modules/systemjs/dist/system.src.js"></script> <script src="systemjs.config.js"></script> <script> System.import('./src/app.vue'); System.import('$DEMOROOT$/en/lib/vue/license.js'); </script> </head> <body> <div id="app"></div> </body> </html>
.sample-tutorial { position: relative; height: 100%; overflow: hidden; } .sample-spreadsheets { width: 100%; height: 100%; overflow: hidden; float: left; } input { display: inline-block; } input[type="text"] { width: 160px; } label { display: inline-block; margin-bottom: 6px; width: 200px; } select { width: 120px; height: 35px; } body { position: absolute; top: 0; bottom: 0; left: 0; right: 0; }
(function (global) { System.config({ transpiler: 'plugin-babel', babelOptions: { es2015: true }, meta: { '*.css': { loader: 'css' }, '*.vue': { loader: 'vue-loader' } }, paths: { // paths serve as alias 'npm:': 'node_modules/' }, // map tells the System loader where to look for things map: { '@mescius/spread-sheets': 'npm:@mescius/spread-sheets/index.js', '@mescius/spread-sheets-vue': 'npm:@mescius/spread-sheets-vue/index.js', '@grapecity/jsob-test-dependency-package/react-components': 'npm:@grapecity/jsob-test-dependency-package/react-components/index.js', 'jszip': 'npm:jszip/dist/jszip.js', 'css': 'npm:systemjs-plugin-css/css.js', 'vue': 'npm:vue/dist/vue.min.js', 'vue-loader': 'npm:systemjs-vue-browser/index.js', 'tiny-emitter': 'npm:tiny-emitter/index.js', 'plugin-babel': 'npm:systemjs-plugin-babel/plugin-babel.js', 'systemjs-babel-build':'npm:systemjs-plugin-babel/systemjs-babel-browser.js' }, // packages tells the System loader how to load when no filename and/or no extension packages: { src: { defaultExtension: 'js' }, rxjs: { defaultExtension: 'js' }, "node_modules": { defaultExtension: 'js' } } }); })(this);